Skip to content

benstahl92/LOSSPhotPypeline

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

LOSSPhotPypeline

This is the Lick Observatory Supernova Search Photometry Pipeline. It is designed to perform photometry on images collected with the KAIT and Nickel telescopes at Lick Observatory (though it could be extended to other telescopes). Python is used to automate, organize, and interact with the pipeline, which itself leverages several other languages (IDL, C, bash) and software packages (DS9, ISIS, SExtractor).

Features

  • as automated as possible
  • clean python interface (no need to interact directly with other languages/software)
  • computationally expensive steps are parallelized
  • detailed logging of every step
  • easy to start/stop/resume/save/reload at any point in the processing

Dependencies

Installation and Setup

  1. Install Dependencies

    • IDL should be installed so that typing idl in a shell starts it with ASTROLIB system variables added
    • DS9 should be installed so that typing ds9 in a shell starts it
    • ISIS should be installed, and the system variable ISISPATH should be set appropriately
    • SExtractor should be installed so that typing sex in a shell runs it

    For Python dependencies see step 3.

  2. Download LOSSPhotPypeline

    git clone https://github.com/benstahl92/LOSSPhotPypeline
  3. Install Python Dependencies

    There are two methods:

    • All in One

      pip install /path/to/LOSSPhotPypeline/

      This uses a new standard where build and setup are all specified in the pyproject.toml file. You may also use poetry or filt to install.

    • Manual

      1. Install all the python dependencies using pip install PACKAGE_NAME for everything except sewpy. For sewpy check their docs.

      2. Add LOSSPhotPypeline to Python's global paths on your user profile (e.g., ~/.bashrc).

        export PYTHONPATH=/path/to/LOSSPhotPypeline/:$PYTHONPATH
  4. Check Installation

    The check_install.py script sets hard-coded paths in the code base where needed and does some basic checks to make sure needed packages and executables are installed appropriately. Once you have downloaded LOSSPhotPypeline and moved it where you'd like it live (call this path /path/to/LOSSPhotPypeline), run this script from the LOSSPhotPypeline root directory.

    # from within the LOSSPhotPypeline root directory
    python check_install.py

    The script will print "Done!" if it runs all the way through successfully.

  5. Set Environment Variables

    Your system needs to know where to find the LOSSPhotPypeline code base. The check_install.py script will print three commands that you can use to set these environment variables. It is recommended that you include these commands in your bash login file (e.g. ~/.bashrc). An example of these three commands follows:

    export PATH="/path/to/LOSSPhotPypeline/LOSSPhotPypeline/utils/LPP_bin:$PATH"
    export IDL_PATH=+/path/to/LOSSPhotPypeline/LOSSPhotPypeline/utils/LPP_idl:$IDL_PATH
    # Below should be uncommented if you used the manual install method
    # export PYTHONPATH=/path/to/LOSSPhotPypeline/:$PYTHONPATH

Running the Pipeline

LOSSPhotPypeline is organized into three subpackages:

  • LOSSPhotPypeline.pipeline provides top-level access to the pipeline and is responsible for running all steps. In normal use, this is the only subpackage that the user will directly interact with.
  • LOSSPhotPypeline.image provides a framework for directly interacting with image files (reading properties, calculating quantities, subtracting host-galaxy light, doing photometry, etc.).
  • LOSSPhotPypeline.utils provides functionality needed by the pipeline including fetching reference catalogs, plotting light curves, etc.

While full documentation is (someday) on its way, an example of a typical workflow is presented below.

  1. Create and enter a working directory for the object (in this case, we call the object "sntest")

    mkdir sntest
    cd sntest
  2. From the python interpreter, import and initialize the pipeline

    >>> import LOSSPhotPypeline.pipeline as lpp
    >>> sn = lpp.start_pipeline('sntest')

    A welcome message will be printed and then (assuming this is the first time running the pipeline in this directory) a template configuration file will be made.

  3. Create a configuration file

    The template configuration file will look something like the following:

    targetname          sntest
    targetra
    targetdec
    photsub             no
    calsource           auto
    photmethod          all
    refname
    photlistfile        sntest.photlist
    forcecolorterm      none
    • The three blank entries must be added --- "targetra" and "targetdec" are the coordinates of the target in decimal degrees, and "refname" is the filename (including relative path) of the image to be used when for determining the coordinates of reference stars.

    • If galaxy subtraction is desired, set "photsub" to "yes". Note that the pipeline will expect to find template images of host galaxy in a directory called "templates". BVRI images should always use template images from the Nickel telescope (even if the science images are from KAIT --- the pipeline will automatically rescale Nickel template images for use with KAIT).

    • Unless you know what you are doing, don't change anything else.

    • Finally, save the configuration as "sntest.conf"

  4. Create photlist file

    As you will see in the configuration file, the pipeline expects there to be a file named "sntest.photlist". This file should contain a single column where each line is the name (including relative path) of an image containing the target to run the pipeline on. The images need not be located in the same place, however it is recommended to organize them in some sort of reasonable way. The pipeline will cause new files to be written in the same directories as the images.

  5. Run the pipeline

    Re-initialize and run the pipeline:

    >>> sn = lpp.start_pipeline('sntest')
    >>> sn.run()

    The pipeline will run through all steps automatically, and keep you apprised of the progress (both through terminal output and a log maintained in "sntest.log"). In the end, this will yield a "lightcurve" directory containing plots and .dat files based on photometry via a number of different apertures.

Miscellaneous notes on running the pipeline

  • Saving and loading

    The pipeline will automatically save its state after successful completion of each step, but the user may manually save the state as well.

    >>> sn.save()

    This creates or updates "sntest.sav", a binary file containing the pipeline state. The pipeline can be restored to the state in "sntest.sav" as follows:

    >>> sn.load()
  • Specific operations

    After running the pipeline, there may be cases where one would like to remove points from a light curve, add new images, check the calibration, etc. Common cases such as these can be handled with minimal effort.

    >>> sn.go_to()
    [...]
     Choose an option:
    
     primary reduction steps:
     0 --- load_images
     1 --- check_images
     2 --- find_ref_stars
     3 --- match_refcal_stars
     4 --- do_galaxy_subtraction_all_image
     5 --- do_photometry_all_image
     6 --- get_sky_all_image
     7 --- do_calibration
     8 --- get_zeromag_all_image
     9 --- get_limmag_all_image
     10 --- generate_lc
     11 --- write_summary
    
     additional options:
     n  --- add new image(s) by filename(s)
     nf --- add new images from file of names
     p  --- plot light curve from file
     c  --- cut points from specific light curve
     cr --- cut points from specific raw light curve and regenerate subsequent light curves
     q  --- quit
    
    selection >
    

    By selecting the appropriate option from "additional options", one can achieve most of these tasks. Notice also the listing of "primary reduction steps", which can be used to reset the pipeline to a certain place in the process if needed (particularly useful if you want to do the calibration manually).

  • Variables and methods

    For those that may need to accomplish more sophisticated tasks than those enumerated above, the following methods can be used see all available instance variables and methods:

    >>> sn.show_variables()
    [...]
    >>> sn.show_methods()
    [...]

A note on calibration

Calibration (as done in the do_calibration reduction step) is the stage of the pipeline that requires the most supervision. It is recommend to run this stage non-interactively the first time, and then see if the results are satisfactory. If they are, great. If not, the process can be run manually with greatly expanded diagnostics and control. An iterative process is employed in an attempt to make the optimal calibration decision. Each iteration consists of a decision and a re-calibration based on that decision. While being run non-interactively, this process does the following:

  1. The first iteration removes calibration stars that are successfully measured in less than 40% of images (this can be disabled by passing the optional argument quality_cuts = False to the do_calibration method).

  2. The second iteration removes images for which less than 40% of the calibration stars are successfully measured in (this can be disabled by passing the optional argument quality_cuts = False to the do_calibration method).

(optional step) By setting the instance variable cal_use_common_ref_stars to True, one can use only the reference stars that are common to all images being processed. If less than 2 reference stars meet this criterion, then "all images" will be loosened to 95% of images. The tolerance will continue to loosen in increments of 5% until at least 2 reference stars satisfy the criterion, however if the tolerance increments below 80% the calibration process exits with a warning. Note: the numbers involved in this check are all instance variables and are hence adjustable. Like steps 1 and 2 above, this check is only performed one time. By default, this check is not performed.

  1. After the above steps are each performed one time, the measured magnitudes of each remaining reference star in every image for each filter/system combination are tabulated and used to identify images that differ by the greater of 3 standard deviations or 0.5 mag from the mean measured magnitude of that reference star in that filter/system. Such differing images are removed, as it is likely that the underlying images were contaminated in some way. These images are logged internally and png versions are saved in the calibration directory for easy review. This step takes precedence over those below (therefore if are any images matching this criteria, they are removed and the data are re-calibrated, regardless of if criteria from the steps below are met).

  2. If the difference between the median difference between measured reference magnitude exceeds 0.05 mag for any calibration star, the one with the largest difference is cut. This procedure iterates until either the aforementioned difference is less than 0.05 mag for all reference stars or only two reference stars remain. If the former, the calibration process ends successfully. If the latter, the tolerance of 0.05 mag is incremented up by 0.05 mag and the process repeats. If the tolerance reaches 0.2 mag without ending successfully, the calibration process exits with a warning.

At the very least, it is important to do a visual inspection of the final reference stars chosen by this process (this can be done by looking at the "ref_stars.png" file that gets written in the calibration directory). If the calibration is unsatisfactory, it is recommended to run the process in interactive mode --- this affords much more control over the steps above. To do this, one needs only to start the pipeline, set the instance variable interactive to True, and go to the appropriate step.

FAQ

  1. Where is my .bashrc file?

    • Linux (or Windows WSL)

      By default if you're using Bash, /home/username/.bashrc.

    • MacOS

      By default, /home/username/.bash-profile. In rare cases you might have a ~/.bashrc file.

    • Windows

      There exist one, but Windows is not supported. Please use a Linux solution (WSL, CygWin, SSH to a Linux machine, etc)

About

Lick Observatory Supernova Search Photometry Pipeline

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •