Skip to content

Commit

Permalink
Merge pull request #142 from kecnry/docs-quickstart
Browse files Browse the repository at this point in the history
basic quickstart examples for spectral extraction
  • Loading branch information
kecnry authored Oct 3, 2022
2 parents 78e68b7 + 478c99c commit f6a834f
Show file tree
Hide file tree
Showing 3 changed files with 138 additions and 26 deletions.
23 changes: 23 additions & 0 deletions docs/api.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
.. _api_index:

API Index
=========

.. automodapi:: specreduce
:no-inheritance-diagram:

.. automodapi:: specreduce.core
:no-inheritance-diagram:

.. automodapi:: specreduce.tracing
:no-inheritance-diagram:

.. automodapi:: specreduce.background
:no-inheritance-diagram:

.. automodapi:: specreduce.extract
:no-inheritance-diagram:

.. automodapi:: specreduce.calibration_data
:no-inheritance-diagram:
:include-all-objects:
93 changes: 93 additions & 0 deletions docs/extraction_quickstart.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,93 @@
.. _extraction_quickstart:

Spectral Extraction Quick Start
===============================

Specreduce provides flexible functionality for extracting a 1D spectrum from a 2D spectral image,
including steps for determining the trace of a spectrum, background subtraction, and extraction.


Tracing
-------

The `specreduce.tracing` module defines the trace of a spectrum on the 2D image. These
traces can either be determined semi-automatically or manually, and are provided as the inputs for
the remaining steps of the extraction process. Supported trace types include:

* `~specreduce.tracing.ArrayTrace`
* `~specreduce.tracing.FlatTrace`
* `~specreduce.tracing.KosmosTrace`


Each of these trace classes takes the 2D spectral image as input, as well as additional information
needed to define or determine the trace (see the API docs above for required parameters for each
of the available trace classes)::

trace = specreduce.tracing.FlatTrace(image, 15)


Background
----------

The `specreduce.background` module generates and subtracts a background image from
the input 2D spectral image. The `~specreduce.background.Background` object is defined by one
or more windows, and can be generated with:

* `~specreduce.background.Background`
* `Background.one_sided <specreduce.background.Background.one_sided>`
* `Background.two_sided <specreduce.background.Background.two_sided>`

The center of the window can either be passed as a float/integer or as a trace::

bg = specreduce.tracing.Background.one_sided(image, trace, separation=5, width=2)


or, equivalently::

bg = specreduce.tracing.Background.one_sided(image, 15, separation=5, width=2)


The background image can be accessed via `~specreduce.background.Background.bkg_image` and the
background-subtracted image via `~specreduce.background.Background.sub_image` (or ``image - bg``).

The background and trace steps can be done iteratively, to refine an automated trace using the
background-subtracted image as input.

Extraction
----------

The `specreduce.extract` module extracts a 1D spectrum from an input 2D spectrum (likely a
background-extracted spectrum from the previous step) and a defined window, using one of the
implemented methods:

* `~specreduce.extract.BoxcarExtract`
* `~specreduce.extract.HorneExtract`

Each of these takes the input image and trace as inputs (see the API above for other required
and optional parameters)::

extract = specreduce.extract.BoxcarExtract(image-bg, trace, width=3)
spectrum = extract.spectrum

The returned ``extract`` object contains all the set options. The extracted 1D spectrum can be
accessed via the ``spectrum`` property or by calling the ``extract`` object (which also allows
temporarily overriding any values)::

spectrum2 = extract(width=6)

Example Workflow
----------------

This will produce a 1D spectrum, with flux in units of the 2D spectrum. The wavelength units will
be pixels. Wavelength and flux calibration steps are not included here.

Putting all these steps together, a simple extraction process might look something like::

from specreduce.trace import FlatTrace
from specreduce.background import Background
from specreduce.extract import BoxcarExtract

trace = FlatTrace(image, 15)
bg = Background.two_sided(image, trace, separation=5, width=2)
extract = BoxcarExtract(image-bg, trace, width=3)
spectrum = extract.spectrum
48 changes: 22 additions & 26 deletions docs/index.rst
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
########################
Specreduce documentation
Specreduce Documentation
########################

The `specreduce <https://specreduce.readthedocs.io/en/latest/index.html>`_ package aims to provide a data reduction toolkit for optical
Expand All @@ -17,16 +17,16 @@ complementary packages.
change. Please feel free to contribute code and suggestions through github.


.. _DR-process:
.. _spectral-extraction:

**********************
Data reduction process
**********************
*******************
Spectral Extraction
*******************

.. toctree::
:maxdepth: 1
:maxdepth: 2

process/index
extraction_quickstart.rst

***********
Calibration
Expand All @@ -38,30 +38,26 @@ Calibration
extinction.rst
specphot_standards.rst

*************
Reference/API
*************

.. automodapi:: specreduce.core
:no-inheritance-diagram:

.. automodapi:: specreduce.tracing
:no-inheritance-diagram:

.. automodapi:: specreduce.background
:no-inheritance-diagram:

.. automodapi:: specreduce.extract
:no-inheritance-diagram:

.. automodapi:: specreduce.calibration_data
:no-inheritance-diagram:
:include-all-objects:

*****
Index
*****

.. toctree::
:maxdepth: 1

api.rst

* :ref:`genindex`
* :ref:`modindex`
* :ref:`search`


****************
Development Docs
****************

.. toctree::
:maxdepth: 1

process/index

0 comments on commit f6a834f

Please sign in to comment.