diff --git a/CHANGES.rst b/CHANGES.rst index f7635444..4ce7192f 100644 --- a/CHANGES.rst +++ b/CHANGES.rst @@ -15,6 +15,8 @@ New Features ^^^^^^^^^^^^ - ``peak_method`` as an optional argument to ``KosmosTrace`` [#115] +- ``Background`` has new methods for exposing the 1D spectrum of the background or + background-subtracted regions [#143] API Changes ^^^^^^^^^^^ diff --git a/specreduce/background.py b/specreduce/background.py index a2829622..1e3f7a55 100644 --- a/specreduce/background.py +++ b/specreduce/background.py @@ -5,8 +5,9 @@ import numpy as np from astropy.nddata import NDData +from astropy import units as u -from specreduce.extract import _ap_weight_image +from specreduce.extract import _ap_weight_image, _to_spectrum1d_pixels from specreduce.tracing import Trace, FlatTrace __all__ = ['Background'] @@ -205,6 +206,27 @@ def bkg_image(self, image=None): return np.tile(self.bkg_array, (image.shape[0], 1)) + def bkg_spectrum(self, image=None): + """ + Expose the 1D spectrum of the background. + + Parameters + ---------- + image : nddata-compatible image or None + image with 2-D spectral image data. If None, will use ``image`` passed + to extract the background. + + Returns + ------- + spec : `~specutils.Spectrum1D` + The background 1d spectrum with flux expressed in the same + units as the input image, or u.DN, and pixel units + """ + bkg_image = self.bkg_image(image=image) + + ext1d = np.sum(bkg_image, axis=self.crossdisp_axis) + return _to_spectrum1d_pixels(ext1d * getattr(image, 'unit', u.DN)) + def sub_image(self, image=None): """ Subtract the computed background from ``image``. @@ -228,6 +250,27 @@ def sub_image(self, image=None): else: return image - self.bkg_image(image) + def sub_spectrum(self, image=None): + """ + Expose the 1D spectrum of the background-subtracted image. + + Parameters + ---------- + image : nddata-compatible image or None + image with 2-D spectral image data. If None, will use ``image`` passed + to extract the background. + + Returns + ------- + spec : `~specutils.Spectrum1D` + The background-subtracted 1d spectrum with flux expressed in the same + units as the input image, or u.DN, and pixel units + """ + sub_image = self.sub_image(image=image) + + ext1d = np.sum(sub_image, axis=self.crossdisp_axis) + return _to_spectrum1d_pixels(ext1d * getattr(image, 'unit', u.DN)) + def __rsub__(self, image): """ Subtract the background from an image. diff --git a/specreduce/extract.py b/specreduce/extract.py index 2537d7ba..56d2b211 100644 --- a/specreduce/extract.py +++ b/specreduce/extract.py @@ -102,6 +102,12 @@ def _ap_weight_image(trace, width, disp_axis, crossdisp_axis, image_shape): return wimage +def _to_spectrum1d_pixels(fluxes): + # TODO: add wavelength units, uncertainty and mask to spectrum1D object + return Spectrum1D(spectral_axis=np.arange(len(fluxes)) * u.pixel, + flux=fluxes) + + @dataclass class BoxcarExtract(SpecreduceOperation): """ @@ -189,12 +195,7 @@ def __call__(self, image=None, trace_object=None, width=None, # extract ext1d = np.sum(image * wimage, axis=crossdisp_axis) - - # TODO: add wavelenght units, uncertainty and mask to spectrum1D object - spec = Spectrum1D(spectral_axis=np.arange(len(ext1d)) * u.pixel, - flux=ext1d * getattr(image, 'unit', u.DN)) - - return spec + return _to_spectrum1d_pixels(ext1d * getattr(image, 'unit', u.DN)) @dataclass @@ -432,10 +433,7 @@ def __call__(self, image=None, trace_object=None, extraction = result * norms # convert the extraction to a Spectrum1D object - pixels = np.arange(img.shape[disp_axis]) * u.pix - spec_1d = Spectrum1D(spectral_axis=pixels, flux=extraction * unit) - - return spec_1d + return _to_spectrum1d_pixels(extraction * unit) @dataclass