Acquisition star statistics
---------------------------
The :mod:`mica.stats.acq_stats` module
includes code to gather acquisition star statistics data for each observation and
return those data to the user.

To get the whole acquisition table data:

   >>> from mica.stats.acq_stats import get_stats
   >>> stats = get_stats()
   >>> stats[(stats['obsid'] == 5438) & (stats['slot'] == 1)][0]['dy']
   8.4296239297976854

The hdf5 in-kernel searches may be faster working with the table directly for some
operations.


Data table fields
^^^^^^^^^^^^^^^^^
The acquisition statistics data table contains the following columns:

=============== ====================================================================
 Column         Description
=============== ====================================================================
obsid           obsid
obi             observation interval number
acq_start       acquisition datestart from kadi event
guide_start     guide transition datestart from kadi event
guide_tstart    guide transition start from kadi event in Chandra secs
one_shot_length one shot delta quaternion arc length for this obsid manvr (arcsec)
revision        revision string representing the software version
slot            ACA readout slot id
idx             starcheck star catalog index id
type            star catalog type (BOT or ACQ)
yang            commanded y-angle position for center of readout window (arcsec)
zang            commanded z-angle position for center of readout window (arcsec)
halfw           acquisition search box half width (arcsec)
mag             catalog MAG_ACA of acquisition star
acqid           acquisition success indicator (boolean)
star_tracked    something tracked within 5 arcsecs during acq interval (boolean)
spoiler_tracked something tracked outside 5 arcsecs during acq interval (boolean)
img_func        image status at transition: can be 'NONE', 'star', 'spoiler', 'RACQ', 'SRCH'
n_trak_interv   number of intervals during acq when something was tracked
max_trak_cdy    max "corrected" delta-y during acquisition (arcsec)
mean_trak_cdy   mean "corrected" delta-y during acquisition (arcsec)
min_trak_cdy    min "corrected" delta-y during acquisition (arcsec)
max_trak_cdz    max "corrected" delta-z during acquisition (arcsec)
mean_trak_cdy   mean "corrected" delta-z during acquisition (arcsec)
min_trak_cdz    min "corrected" delta-z during acquisition (arcsec)
max_trak_mag    max observed magnitude during acquisition
mean_trak_mag   mean observed magnitude during acquisition
min_trak_mag    min observed magnitude during acquisition
cdy             "corrected" (see below) delta-y at guide transition. (arcsec)
cdy             "corrected" (see below) delta-z at guide transition (arcsec)
dy              delta-y at guide transition. expected position (see below) determined using onboard est. attitude (arcsec)
dz              delta-z at guide transition. expected position (see below) determined using onboard est. attitude (arcsec)
ion_rad         ionizing radiation flag set at transition (boolean)
def_pixel       defective pixel flag set at transition (boolean)
mult_star       multiple star flag set at transition (boolean)
sat_pix         saturated pixel flag set at transition (boolean)
mag_obs         observed magnitude at transition
yang_obs        observed y-angle at transition (arcsec)
zang_obs        observed z-angle at transition (arcsec)
agasc_id        AGASC (catalog) id
color1          AGASC COLOR1, estimated B-V color
ra              AGASC right ascension (degrees)
dec             AGASC declination (degrees)
epoch           AGASC EPOCH
pm_ra           AGASC PM_RA, proper motion in ra (milli-arcsec/year)
pm_dec          AGASC PM_DEC, proper motion in dec (milli-arsec/year)
var             AGASC VAR, known or suspected variable star
pos_err         AGASC POS_ERR, position error (milli-arcsec)
mag_aca         AGASC MAG_ACA, ACA mag
mag_err         AGASC MAG_ERR, (to be fixed, this should have been MAG_ACA_ERR)
mag_band        AGASC MAG_BAND, integer code for spectral band
pos_catid       AGASC POS_CATID, integer code for position catalog
aspq1           AGASC ASPQ1, integer spoiler code
aspq2           AGASC ASPQ2, integer proper motion flag
aspq3           AGASC ASPQ3, integer dist in 100m-arcsec to nearest Tycho2 star
acqq1           AGASC ACQQ1, mag diff to brightest star within 53.3" (0.01mags)
acqq2           AGASC ACQQ2, mag diff to brightest star within 107" (0.01mags)
acqq4           AGASC ACQQ4, mag diff to brightest star within 267.5" (0.01mags)
n100_warm_frac  estimated n100 fraction of CCD pixels for this observation
ccd_temp        mean CCD temperature over 500 seconds surrounding guide transition
known_bad       ignore this star in standard processing (boolean)
bad_comment     reason to ignore a "known_bad" star
=============== ====================================================================

Note that dy/dz are observed yag/zag (t_guide) - predicted yag/zag (t_guide) using AOATTQT
(estimated attitude). Observed yag/zag are from AOAC{Y,Z}AN, and t_guide is the time of
the first sample with AOACASEQ = 'GUID'. t_guide is the same as manvrs.guide_start in
kadi. The one-shot attitude update occurs in telemetry on the sample after the GUID
transition.  In particular, dy/dz are used in the check for wrong box acquisition anomaly
as the the estimated attitude for dy/dz gives a reasonable approximation of the
OBC estimated attitude at the time of commanding the search boxes. (though the estimated attitude at
t_acq would be even better for that)

For the columns that reference "corrected" y-angle and z-angle, cdy/cdz, these are the
observed yag/zag (t_guide) - predicted yag/zag (t_guide) using the estimated attitude at
that time transformed/corrected by the one-shot quaternion (which is actually calculated from the
*next* one or two samples).


Processing
^^^^^^^^^^

For each observation, after the observation has run and telemetry is available, the
acquisition and guide stats process does the following:

* Fetches the AGASC information for each star in the catalog
* Fetches the PCAD data at the end of the acquisition interval
* For each acquisition star determines:

  * If that star was "successfully" acquired
  * What the observed magnitude and position of the star were in the last PCAD telemetry
    readout before the guide transition.