diff options
| author | Aaron LI <aaronly.me@outlook.com> | 2017-02-16 15:57:00 +0800 | 
|---|---|---|
| committer | Aaron LI <aaronly.me@outlook.com> | 2017-02-17 01:16:46 +0800 | 
| commit | 0ad65eddf5abda46d9a1d05ea3f3d8a5c160c4d8 (patch) | |
| tree | 1a661d9aa99ad7ce01dd6dc9356d1274aec1a2b2 /scripts | |
| parent | 00e26ca0a14f7918d9bbc4cb5d0d3afa2334b1fe (diff) | |
| download | chandra-acis-analysis-0ad65eddf5abda46d9a1d05ea3f3d8a5c160c4d8.tar.bz2 | |
Add acis.py and spectrum.py modules
Also add astropy to the runtime dependencies.
Diffstat (limited to 'scripts')
| -rw-r--r-- | scripts/acis.py | 34 | ||||
| -rw-r--r-- | scripts/spectrum.py | 44 | 
2 files changed, 78 insertions, 0 deletions
| diff --git a/scripts/acis.py b/scripts/acis.py new file mode 100644 index 0000000..5200f4e --- /dev/null +++ b/scripts/acis.py @@ -0,0 +1,34 @@ +# Copyright (c) 2017 Weitian LI <liweitianux@live.com> +# MIT license + +""" +Chandra ACIS utilities +""" + +import math + + +class ACIS: +    """ +    Chandra ACIS detector properties and utilities. + +    References +    ---------- +    [1] CIAO - dictionary - ACIS (advanced camera for imaging and spectroscopy) +        http://cxc.harvard.edu/ciao/dictionary/acis.html +    [2] CIAO - Dictionary - PI (pulse invariant) +        http://cxc.harvard.edu/ciao/dictionary/pi.html +    """ +    # Pixel size +    pixel2arcsec = 0.492  # [arcsec] +    # Number of channels +    nchannel = 1024 +    # Channel energy width +    echannel = 14.6  # [eV] + +    @classmethod +    def energy2channel(self, energy): +        """ +        Convert energy [eV] to channel number. +        """ +        return math.floor(energy/self.echannel + 1) diff --git a/scripts/spectrum.py b/scripts/spectrum.py new file mode 100644 index 0000000..ad38b0d --- /dev/null +++ b/scripts/spectrum.py @@ -0,0 +1,44 @@ +# Copyright (c) 2017 Weitian LI <liweitianux@live.com> +# MIT license + +""" +Chandra ACIS spectrum. +""" + + +from astropy.io import fits + +from acis import ACIS + + +class Spectrum: +    """ +    Chandra ACIS spectrum +    """ +    def __init__(self, filepath): +        self.filepath = filepath +        self.fitsobj = fits.open(filepath) +        ext_spec = self.fitsobj["SPECTRUM"] +        self.header = ext_spec.header +        # spectral data +        self.channel = ext_spec.data.columns["CHANNEL"].array +        self.counts = ext_spec.data.columns["COUNTS"].array +        # spectral keywords +        self.EXPOSURE = self.header.get("EXPOSURE") +        self.BACKSCAL = self.header.get("BACKSCAL") + +    def calc_pb_flux(self, elow=9500, ehigh=12000): +        """ +        Calculate the particle background flux: +            flux = counts / exposure / area + +        Parameters +        ---------- +        elow, ehigh : float, optional +            Lower and upper energy limit for the particle background. +        """ +        chlow = ACIS.energy2channel(elow) +        chhigh = ACIS.energy2channel(ehigh) +        counts = self.counts[(chlow-1):chhigh].sum() +        flux = counts / self.EXPOSURE / self.BACKSCAL +        return flux | 
