lsst.obs.base¶
The lsst.obs.base
module provides the framework and common API for telescope/camera specific “obs” packages.
New cameras will derive from the classes defined here.
lsst.obs.base.tests
provides the tests that all “obs” packages should pass.
Using lsst.obs.base¶
Contributing¶
lsst.obs.base
is developed at https://github.com/lsst/obs_base.
You can find Jira issues for this module under the obs_base component.
Command Line Interface¶
daf_butler
implements a command line interface command called butler
. The following subcommands are
implemented by this package and available to the butler
command when this package is setup.
butler¶
butler [OPTIONS] COMMAND [ARGS]...
convert¶
Convert one or more Butler gen 2 repositories into a gen 3 repository.
REPO is the URI or path to the gen3 repository. Will be created if it does not already exist
This is a highly simplified interface that should only be used to convert suites of gen 2 repositories that contain at most one calibration repo and has no chained reruns. Custom scripts that call ConvertRepoTask should be used on more complex suites of repositories.
butler convert [OPTIONS] REPO
Options
-
--gen2root
<gen2root>
¶ Required Root path of the gen 2 repo to be converted.
-
--skymap-name
<skymap_name>
¶ Name of the new gen3 skymap (e.g. ‘discrete/ci_hsc’).
-
--skymap-config
<skymap_config>
¶ Path to skymap config file defining the new gen3 skymap.
-
--calibs
<calibs>
¶ Path to the gen 2 calibration repo. It can be absolute or relative to gen2root.
-
--reruns
<TEXT ...>
¶ List of rerun paths to convert. Output collection names will be guessed, which can fail if the Gen2 repository paths do not follow a recognized convention. In this case, the command-line interface cannot be used.
-
-t
,
--transfer
<transfer>
¶ Mode to use to transfer files into the new repository.
Options: auto|link|symlink|hardlink|copy|move|relsymlink|direct
-
-j
,
--processes
<processes>
¶ Number of processes to use.
-
-C
,
--config-file
<config_file>
¶ Path to a
ConvertRepoConfig
override to be included after the Instrument config overrides are applied.
-
-
@
,
--options-file
<options_file>
¶ URI to YAML file containing overrides of command line options. The YAML should be organized as a hierarchy with subcommand names at the top level options for that subcommand below.
Arguments
-
REPO
¶
Required argument
See ‘butler –help’ for more options.
define-visits¶
Define visits from exposures in the butler registry.
REPO is the URI or path to the gen3 repository. Will be created if it does not already exist
The name or fully-qualified class name of an instrument.
butler define-visits [OPTIONS] REPO INSTRUMENT
Options
-
-C
,
--config-file
<config_file>
¶ Path to a pex_config override to be included after the Instrument config overrides are applied.
-
--collections
<TEXT ...>
¶ The collections to be searched (in order) when reading datasets.
-
-j
,
--processes
<processes>
¶ Number of processes to use.
-
-
@
,
--options-file
<options_file>
¶ URI to YAML file containing overrides of command line options. The YAML should be organized as a hierarchy with subcommand names at the top level options for that subcommand below.
Arguments
-
REPO
¶
Required argument
-
INSTRUMENT
¶
Required argument
See ‘butler –help’ for more options.
ingest-raws¶
Ingest raw frames into from a directory into the butler registry
REPO is the URI or path to the gen3 repository. Will be created if it does not already exist
LOCATIONS specifies files to ingest and/or locations to search for files.
butler ingest-raws [OPTIONS] REPO LOCATIONS ...
Options
-
--regex
<regex>
¶ Regex string used to find files in directories listed in LOCATIONS. Searches for fits files by default.
-
-c
,
--config
<TEXT=TEXT>
¶ Config override, as a key-value pair.
-
-C
,
--config-file
<config_file>
¶ Path to a pex config override to be included after the Instrument config overrides are applied.
-
--output-run
<output_run>
¶ The name of the run datasets should be output to.
-
-t
,
--transfer
<transfer>
¶ The external data transfer mode.
Options: auto|link|symlink|hardlink|copy|move|relsymlink|direct
-
-j
,
--processes
<processes>
¶ Number of processes to use.
-
--ingest-task
<ingest_task>
¶ The fully qualified class name of the ingest task to use.
-
-
@
,
--options-file
<options_file>
¶ URI to YAML file containing overrides of command line options. The YAML should be organized as a hierarchy with subcommand names at the top level options for that subcommand below.
Arguments
-
REPO
¶
Required argument
-
LOCATIONS
¶
Required argument(s)
See ‘butler –help’ for more options.
register-instrument¶
Add an instrument to the data repository.
REPO is the URI or path to the gen3 repository. Will be created if it does not already exist
The fully-qualified name of an Instrument subclass.
butler register-instrument [OPTIONS] REPO INSTRUMENT ...
Arguments
-
REPO
¶
Required argument
-
INSTRUMENT
¶
Required argument(s)
See ‘butler –help’ for more options.
write-curated-calibrations¶
Add an instrument’s curated calibrations to the data repository.
REPO is the URI or path to the gen3 repository. Will be created if it does not already exist
The fully-qualified name of an Instrument subclass.
butler write-curated-calibrations [OPTIONS] REPO INSTRUMENT
Options
-
--collection
<collection>
¶ Name of the calibration collection that associates datasets with validity ranges.
-
--label
<labels>
¶ Extra strings to include (with automatic delimiters) in all RUN collection names, as well as the calibration collection name if it is not provided via –collection.
-
-
@
,
--options-file
<options_file>
¶ URI to YAML file containing overrides of command line options. The YAML should be organized as a hierarchy with subcommand names at the top level options for that subcommand below.
Arguments
-
REPO
¶
Required argument
-
INSTRUMENT
¶
Required argument
See ‘butler –help’ for more options.
Python API reference¶
lsst.obs.base Package¶
Functions¶
bboxFromIraf (irafBBoxStr) |
Return a Box2I corresponding to an IRAF-style BBOX |
createInitialSkyWcs (visitInfo, detector[, flipX]) |
Create a SkyWcs from the visit information and detector geometry. |
createInitialSkyWcsFromBoresight (boresight, …) |
Create a SkyWcs from the telescope boresight and detector geometry. |
exposureFromImage (image[, dataId, mapper, …]) |
Generate an Exposure from an image-like object |
loadCamera (butler, dataId, Mapping[str, …) |
Attempt to load versioned camera geometry from a butler, but fall back to obtaining a nominal camera from the Instrument class if that fails. |
makeExposureRecordFromObsInfo (obsInfo, universe) |
Construct an exposure DimensionRecord from astro_metadata_translator.ObservationInfo . |
makeTransferChoiceField ([doc, default]) |
Create a Config field with options for how to transfer files between data repositories. |
Classes¶
CalibrationMapping (datasetType, policy, …) |
CalibrationMapping is a Mapping subclass for calibration-type products. |
CameraMapper (policy, repositoryDir[, root, …]) |
CameraMapper is a base class for mappers that handle images from a camera and products derived from them. |
DatasetMapping (datasetType, policy, …) |
DatasetMapping is a Mapping subclass for non-Exposure datasets that can be retrieved by the standard daf_persistence mechanism. |
DefineVisitsConfig |
|
DefineVisitsTask (config, *, butler, **kwargs) |
Driver Task for defining visits (and their spatial regions) in Gen3 Butler repositories. |
ExposureIdInfo ([expId, expBits, maxBits]) |
Exposure ID and number of bits used. |
ExposureMapping (datasetType, policy, …) |
ExposureMapping is a Mapping subclass for normal exposures. |
FilterDefinition (physical_filter, lambdaEff, …) |
The definition of an instrument’s filter bandpass. |
FilterDefinitionCollection (*filters) |
An order-preserving collection of multiple FilterDefinition . |
FitsRawFormatterBase (*args, **kwargs) |
Abstract base class for reading and writing raw data to and from FITS files. |
GroupExposuresConfig |
|
GroupExposuresTask (config, **kwargs) |
Abstract base class for the subtask of DefineVisitsTask that is responsible for grouping exposures into visits. |
ImageMapping (datasetType, policy, registry, …) |
ImageMapping is a Mapping subclass for non-camera images. |
InitialSkyWcsError |
For handling failures when creating a SkyWcs from a camera geometry and boresight. |
Instrument () |
Base class for instrument-specific logic for the Gen3 Butler. |
MakeRawVisitInfo ([log, doStripHeader]) |
Base class functor to make a VisitInfo from the FITS header of a raw image. |
MakeRawVisitInfoViaObsInfo ([log, doStripHeader]) |
Base class functor to make a VisitInfo from the FITS header of a raw image using ObservationInfo translators. |
Mapping (datasetType, policy, registry, …) |
Mapping is a base class for all mappings. |
RawIngestConfig |
|
RawIngestTask (config, *, butler, **kwargs) |
Driver Task for ingesting raw data into Gen3 Butler repositories. |
VisitDefinitionData (instrument, id, name, …) |
Struct representing a group of exposures that will be used to define a visit. |
Class Inheritance Diagram¶
lsst.obs.base.formatters.fitsExposure Module¶
Classes¶
FitsExposureFormatter (fileDescriptor, …) |
Interface for reading and writing Exposures to and from FITS files. |
FitsImageFormatter (fileDescriptor, dataId, …) |
Specialisation for Image reading. |
FitsMaskFormatter (fileDescriptor, dataId, …) |
Specialisation for Mask reading. |
FitsMaskedImageFormatter (fileDescriptor, …) |
Specialisation for MaskedImage reading. |
Class Inheritance Diagram¶
lsst.obs.base.formatters.fitsGeneric Module¶
Classes¶
FitsGenericFormatter (fileDescriptor, dataId, …) |
Interface for reading and writing objects that support the standard afw I/O readFits/writeFits methods. |