astro_metadata_translator¶
The astro_metadata_translator
package provides generalized infrastructure
for handling metadata extraction for astronomical instrumentation.
There are header translation classes implemented as subclasses of
MetadataTranslator
. These translation subclasses
implement methods corresponding to each derived property defined in
ObservationInfo
. The methods are named
to_{property}
and can be implemented explicitly by a translation class, or
implicitly by defining trivial mappings from a header item to a property, or
constant mappings that are fixed for all headers independent of any header
values.
Defining a new translator subclass that inherits from
MetadataTranslator
and giving it a name,
automatically registers the translator as being available for automated header
translation.
A translation class does not need to reside in the
astro_metadata_translator
package.
ObservationInfo
is a class summarizing the
information from the translators.
An instance of this class can be instantiated from
any dict
-like header. By default the header translation class to use
is determined by asking each registered translator whether it knows how to
translate it. If an explicit translation class should be used it can be
specified explicitly.
For details on the format of header correction files see fix_header
.
Warning
The existing set of property names in
ObservationInfo
should be considered as beta
quality.
Some of the names could yet be changed for consistency with other data
dictionaries.
Entry Points¶
Translators in other packages are automatically registered with the translation system when they are imported.
To simplify the user experience when specifying that an external translator should be imported by the command-line tooling, an external package can define entry points in its pyproject.toml
.
For example:
[project.entry-points.astro_metadata_translators]
obs_lsst = "lsst.obs.lsst.translators:_register_translators"
The label (here obs_lsst
) is what the user can specify with -p
, and the entry point itself has two requirements.
Firstly, on loading the entry point all the translators must be loaded (so that they register themselves) and secondly, the function specified must return the names of the translators.
These names are used with the --list-plugins
command-line option to give an indication to the user as to what instruments they support.
Project info¶
Command Line Utilities¶
If an external package has a astro_metadata_translators
entry point defined in its pyproject.toml
that entry point can be loaded by name with the -p
option to the command line tools instead of using a full python path to the translator code.
The full set of available plugin names can be obtained using astrometadata --list-plugins translate
.
astrometadata¶
Execute main click command-line.
astrometadata [OPTIONS] COMMAND [ARGS]...
Options
- --log-level <log_level>¶
Python logging level to use.
- Options:
CRITICAL | ERROR | WARNING | INFO | DEBUG
- --traceback, --no-traceback¶
Give detailed trace back when any errors encountered.
- -p, --packages <packages>¶
Python packages or plugin names to import to register additional translators. This is in addition to any packages specified in the METADATA_TRANSLATORS environment variable (colon-separated python module names or plugin names).
- --list-plugins, --no-list-plugins¶
List all available registered plugins. If true, the command will return immediately.
dump¶
Dump data header to standard out in YAML format.
astrometadata dump [OPTIONS] [FILES]...
Options
- -n, --hdrnum <hdrnum>¶
HDU number to read. If the HDU can not be found, a warning is issued but reading is attempted using the primary header. The primary header is always read and merged with this header. Negative number (the default) indicates that the second header will be merged if the FITS file supports extended FITS.
- -m, --mode <mode>¶
Output mode. ‘yaml’ dumps the header in YAML format (this is the default). ‘fixed’ dumps the header in YAML format after applying header corrections. ‘yamlnative’ is as for ‘yaml’ but dumps the native (astropy vs PropertyList) native form. ‘yamlfixed’ is as for ‘fixed’ but dumps the native (astropy vs PropertyList) native form.
- Options:
yaml | fixed | yamlnative | fixexnative
- -r, --regex <regex>¶
When looking in a directory, regular expression to use to determine whether a file should be examined. Default: ‘.fit[s]?b’
Arguments
- FILES¶
Optional argument(s)
translate¶
Translate metadata in supplied files and report.
astrometadata translate [OPTIONS] [FILES]...
Options
- -q, --quiet, --no-quiet¶
Do not report the translation content from each header. Only report failures.
- -n, --hdrnum <hdrnum>¶
HDU number to read. If the HDU can not be found, a warning is issued but reading is attempted using the primary header. The primary header is always read and merged with this header. Negative number (the default) indicates that the second header will be merged if the FITS file supports extended FITS.
- -m, --mode <mode>¶
Output mode. ‘verbose’ prints all available information for each file found. ‘table’ uses tabular output for a cutdown set of metadata. ‘auto’ uses ‘verbose’ if one file found and ‘table’ if more than one is found.
- Options:
auto | verbose | table
- -r, --regex <regex>¶
When looking in a directory, regular expression to use to determine whether a file should be examined. Default: ‘.fit[s]?b’
Arguments
- FILES¶
Optional argument(s)
write-index¶
Write JSON index file for entire directory.
astrometadata write-index [OPTIONS] [FILES]...
Options
- -n, --hdrnum <hdrnum>¶
HDU number to read. If the HDU can not be found, a warning is issued but reading is attempted using the primary header. The primary header is always read and merged with this header. Negative number (the default) indicates that the second header will be merged if the FITS file supports extended FITS.
- -r, --regex <regex>¶
When looking in a directory, regular expression to use to determine whether a file should be examined. Default: ‘.fit[s]?b’
- -c, --content <content>¶
Content to store in JSON file. Options are: ‘translated’ stores translated metadata in the file; ‘metadata’ stores raw FITS headers in the file.
- Options:
translated | metadata
- -o, --outpath <outpath>¶
If given, write a single index with all information in specified location. Default is to write one index per directory where files are located.
Arguments
- FILES¶
Optional argument(s)
write-sidecar¶
Write JSON sidecar files alongside each data file.
astrometadata write-sidecar [OPTIONS] [FILES]...
Options
- -n, --hdrnum <hdrnum>¶
HDU number to read. If the HDU can not be found, a warning is issued but reading is attempted using the primary header. The primary header is always read and merged with this header. Negative number (the default) indicates that the second header will be merged if the FITS file supports extended FITS.
- -r, --regex <regex>¶
When looking in a directory, regular expression to use to determine whether a file should be examined. Default: ‘.fit[s]?b’
- -c, --content <content>¶
Content to store in JSON file. Options are: ‘translated’ stores translated metadata in the file; ‘metadata’ stores raw FITS headers in the file.
- Options:
translated | metadata
Arguments
- FILES¶
Optional argument(s)
Python API reference¶
astro_metadata_translator Package¶
Functions¶
|
Cache the result of a translation method. |
|
Update, in place, the supplied header with known corrections. |
|
Construct an |
|
Merge multiple headers into a single dict. |
Classes¶
|
Metadata translator for DECam standard headers. |
|
Metadata translator for FITS standard headers. |
|
Metadata translator for HSC standard headers. |
|
Metadata translator for CFHT MegaPrime standard headers. |
|
Per-instrument metadata translation support. |
|
A collection of |
|
Standardized representation of an instrument header for a single exposure observation. |
|
Definition of an instrumental property. |
|
Metadata translator for SDSS standard headers. |
|
Translator where all the translations are stubbed out and issue warnings. |
|
Metadata translator for Subaru telescope headers. |
|
Metadata translator for HSC standard headers. |
Class Inheritance Diagram¶
astro_metadata_translator.indexing Module¶
Functions to support file indexing.
Functions¶
Read an index file. |
|
|
Read a metadata sidecar file. |
|
Calculate an index data structure from the supplied headers. |
|
Create an index from the supplied files. |
Process the content read from a JSON index file. |
|
Process the content read from a JSON sidecar file. |
astro_metadata_translator.file_helpers Module¶
Support functions for script implementations.
These functions should not be treated as part of the public API.
Functions¶
|
Find files for processing. |
|
Read a raw header from a file, merging if necessary. |
|
Read information from file. |