Running the AP pipeline (Gen 3)¶
Setup¶
Pick up where you left off in Getting Started. This means you already have a repository of ingested DECam data and have set up the LSST Science Pipelines stack.
Your repository should have the following collections, which can be checked using butler query-collections <repo>
:
DECam/calib: biases, flats, defects, camera specs, etc.
DECam/raw/all: images to be processesd
refcats: reference catalogs for calibration
skymaps: index for the templates
templates/deep:
deepCoadd
templates for difference imaging
AP pipeline on the command line¶
Like most Vera Rubin Observatory pipelines, the AP Pipeline is run with an external runner called pipetask
.
This can be found in the ctrl_mpexec
package, which is included as part of lsst_distrib
.
The pipeline itself is configured in ap_pipe/pipelines/ApPipe.yaml.
To process your ingested data, run
mkdir apdb/
make_apdb.py -c isolation_level=READ_UNCOMMITTED -c db_url="sqlite:///apdb/association.db"
pipetask run -p ${AP_PIPE_DIR}/pipelines/ApPipe.yaml --instrument lsst.obs.decam.DarkEnergyCamera --register-dataset-types -c diaPipe:apdb.isolation_level=READ_UNCOMMITTED -c diaPipe:apdb.db_url="sqlite:///apdb.db" -b repo/ -i "templates/deep,skymaps,DECam/raw/all,DECam/calib,refcats" -o processed -d "visit in (123456, 123457) and detector=42"
In this case, a processed/<timestamp>
collection will be created within repo
and the results will be written there.
See Setting up the Alert Production Database for ap_pipe for more information on make_apdb.py.
This example command only processes observations corresponding to visits 123456 and 123457, both with only detector 42 (the Gen 2 terms “ccd” and “ccdnum” are no longer used).
The example creates a “chained” output collection that can refer back to its inputs. If you prefer to have a standalone output collection, you may instead run
pipetask run -p ${AP_PIPE_DIR}/pipelines/ApPipe.yaml --instrument lsst.obs.decam.DarkEnergyCamera --register-dataset-types -c diaPipe:apdb.isolation_level=READ_UNCOMMITTED -c diaPipe:apdb.db_url="sqlite:///apdb.db" -b repo/ -i "templates/deep,skymaps,DECam/raw/all,DECam/calib,refcats" --output-run processed -d "visit in (123456, 123457) and detector=42"
Note
If you are using the default (SQLite) association database, you must configure the database location, or ap_pipe
will not run.
The location is a path to a new or existing database file to be used for source associations (including associations with previously known objects, if the database already exists).
In the examples above, it is configured with the -c
option, but a personal config file may be more convenient if you intend to run ap_pipe
many times.
Note
Both examples above are only valid when running the pipeline for the first time.
When rerunning with an existing chained collection using -o
, you must omit the -i
argument.
When rerunning with an existing standalone collection using --output-run
, you must pass --extend-run
.
Expected outputs¶
If you used the chained option above, most of the output from ap_pipe
should be written to a timestamped collection (e.g., processed/20200131T00h00m00s
) in the repository.
The exception is the source association database, which will be written to the location you configure.
The result from running ap_pipe
should look something like
apdb/
association.db <--- the Alert Production Database with DIAObjects
repo/
contains_no_user_servicable_files/
To inspect this data with the Butler, you should instantiate a Butler within python and access the data products that way.
For example, in python
import lsst.daf.butler as dafButler
butler = dafButler.Butler('repo', collections="processed") # collections keyword is optional
dataId = {'instrument': 'DECam', 'visit': 123456, 'detector': 42}
calexp = butler.get('calexp', dataId=dataId)
diffim = butler.get('deepDiff_differenceExp', dataId=dataId)
diaSourceTable = butler.get('deepDiff_diaSrc', dataId=dataId)
Supplemental information¶
Running on other cameras¶
Running ap_pipe on cameras other than DECam works much the same way:. You need to provide a repository containing raws, calibs, and templates appropriate for the camera.
Common errors¶
‘KeyError: DatasetType <type> could not be found’: This usually means you left out the
--register-dataset-types
argument.‘Expected exactly one instance of input <arbitrary dataset>’: This may mean an invalid pipeline, but can also mean that you did not provide an
-i
or--input
argument when it was required. This is especially likely if the data ID is not one of the expected values.