Please note that what is described here is based on Shannon & Boersma (2018) and some implementation details will have changed since then.
2 Design
Pypahdb analyzes spectroscopic observations (including spectral maps) and characterizes the PAH emission in terms of PAH ionization and size fractions using a database-fitting approach.
The pypahdb package is imported with the following statement:
import pypahdb
2.1 Flowchart
The general program methodology is encapsulated in the flowchart presented in the figure above and is as follows:
Read-in a file containing spectroscopic PAH observations of an astronomical object. This functionality is provided by the class
Observation
, which is implemented inobservation.py
. It is the responsibility of the user to ensure all non-PAH emission components have been removed from the spectrum. The class uses a fall-through try-except chain to attempt to read the given filename using the facilities provided byastropy.io
. The spectroscopic data is stored as aspecutils.Spectrum1D
object. TheSpectrum1D
class provides functionality to convert between different coordinate representations. Below is example Python code demonstrating the use of the class. The filesample_data_NGC7023.tbl
in this demonstration is bundled with the pypahdb package. The output of the demonstration code is shown in the flowchart.
import pkg_resources
import matplotlib.pyplot as plt
from pypahdb.observation import Observation
file_path = 'resources/sample_data_NGC7023.tbl'
data_file = pkg_resources.resource_filename('pypahdb', file_path)
obs = Observation(data_file)
s = obs.spectrum
plt.plot(s.spectral_axis, s.flux[0,0,:])
plt.show()
Decompose the observed PAH emission in terms of contributing PAH subclasses, here charge and size. This functionality is provided by the class
Decomposer
, which is implemented indecomposer.py
and takesdecomposer_base.py
as its base. TheDecomposer
class takes as input aSpectrum1D
object, of which it takes a deep copy and calls theUnit.to
method on to convert the abscissa units to wavenumber. Subsequently, a pre-computednumpy
matrix of highly oversampled PAH emission spectra stored as apickle
is loaded from file. Utilizingnumpy.interp
, each of the PAH emission spectra, represented by a single column in the pre-computed matrix, is interpolated onto the frequency grid (in wavenumber) of the input spectrum. This process is parallelized using themultiprocessing
package.optimize.nnls
is used to perform a non-negative least-squares (NNLS) fit of the interpolated, pre-computed spectra to the input spectra. NNLS is chosen because it is appropriate to the problem, fast, and always converges. The solution vector (weights) is stored as an attribute and considered private toDecomposer
. Combining lazy instantiation and Python’s @property, the fit and the breakdown can be retrieved. When the input spectrum represents a spectral cube the calculations are parallelized across each pixel using, again, themultiprocessing
package. Below is example code demonstrating the use of theDecomposer
and extends the previous code-block. The output from the code-block is shown in the flowchart.
from pypahdb.decomposer import Decomposer
result = Decomposer(obs.spectrum)
s = result.spectrum
plt.plot(s.spectral_axis, s.flux[0,0,:], 'x')
plt.plot(s.spectral_axis, result.fit[:,0,0])
plt.show()
Save the results to file. The output summarizes the results from the
Decomposer
class to allow users assessing the quality of the fit and store the derived PAH properties for later retrieval. TheDecomposer
class usesastropy.fits
to write FITS-files. The class will attempt to incorporate relevant information when a (FITS) header is provided. Below is example code demonstrating the use of the class, which extends the previous code-block. The output from the code-block is shown in the flowchart.
result.save_pdf('NGC7023_pypahdb.pdf')
result.save_fits('NGC7023_pypahdb.fits', header=obs.header)
2.2 Supported data formats
Pypahdb supports reading in IPAC tables, Spitzer FITS files, and JWST FITS files. Support for reading pahfit[1]-files is underway. Pahfit is being developed as part of the same JWST ERS Program[2] as pypahdb.