-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathget_data_hlsp_k2sc.py
139 lines (118 loc) · 5.86 KB
/
get_data_hlsp_k2sc.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
"""
.. module:: get_data_hlsp_k2sc
:synopsis: Returns K2SC lightcurve data as a JSON string.
.. moduleauthor:: Scott W. Fleming <fleming@stsci.edu>
"""
import collections
import numpy
from astropy.io import fits
from data_series import DataSeries
from parse_obsid_hlsp_k2sc import parse_obsid_hlsp_k2sc
#--------------------
def get_data_hlsp_k2sc(obsid):
"""
Given a K2SC observation ID, returns the lightcurve data.
:param obsid: The K2SC observation ID to retrieve the data from.
:type obsid: str
:returns: JSON -- The lightcurve data for this observation ID.
Error codes:
From parse_obsid_hlsp_k2sc:
0 = No error.
1 = Error parsing K2SC observation ID.
2 = Cadence not recognized as long cadence.
3 = File is missing on disk.
From this module:
4 = FITS file does not have the expected number of FITS extensions.
5 = Could not open FITS file for reading.
6 = All values were non-finite in x and/or y.
"""
# This defines a data point for a DataSeries object as a namedtuple.
data_point = collections.namedtuple('DataPoint', ['x', 'y'])
# For K2SC, this defines the x-axis and y-axis units as a string.
k2sc_xunit = "BJD"
k2sc_yunit = "electrons / second"
# Parse the obsID string to determine the paths+files to read. Note:
# this step will assign some of the error codes returned to the top level.
parsed_file_result = parse_obsid_hlsp_k2sc(obsid)
if parsed_file_result.errcode == 0:
# For each file, read in the contents and create a return JSON object.
all_plot_labels = ['']*2*len(parsed_file_result.files)
all_plot_series = ['']*2*len(parsed_file_result.files)
all_plot_xunits = ['']*2*len(parsed_file_result.files)
all_plot_yunits = ['']*2*len(parsed_file_result.files)
# This error code will be used unless there's a problem reading any of
# the FITS files in the list.
errcode = 0
for i, kfile in enumerate(parsed_file_result.files):
try:
with fits.open(kfile) as hdulist:
# Extract time stamps and relevant fluxes. Note that for
# K2SC there are 2 relevant extensions. The first
# extension is the detrended PDCSAP lightcurve, the second
# is the detrended SAP lightcurve.
if len(hdulist) == 3:
for j in range(1, 3):
# Extension name.
extname = hdulist[j].header["EXTNAME"].strip()
# Timestamps.
bjd = hdulist[j].data["time"] + 2454833.0
# Corrected flux.
cor_flux = hdulist[j].data["flux"]
# Only keep those points that don't have NaN's in
# them.
where_keep = numpy.where(
(numpy.isfinite(bjd)) &
(numpy.isfinite(cor_flux)))[0]
if where_keep.size > 0:
bjd = bjd[where_keep]
cor_flux = cor_flux[where_keep]
else:
errcode = 6
# Create the plot label and plot series for the
# extracted and detrended fluxes.
this_plot_label = (
'K2SC_' + parsed_file_result.k2scid + ' ' +
parsed_file_result.campaign.upper() + ' ' +
extname)
# Note that the indexes are (j-1) since j loops
# over the extension number, but the lists are
# zero-indexed, so "k" is the insert index.
if errcode == 0:
# Get arrays into regular list with decimal
# limits.
bjd = [float("{0:.8f}".format(x)) for x in bjd]
cor_flux = [float("{0:.8f}".format(x))
for x in cor_flux]
k = j-1
all_plot_labels[k] = this_plot_label
all_plot_series[k] = [
data_point(x=x, y=y) for
x, y in zip(bjd, cor_flux)]
all_plot_xunits[k] = k2sc_xunit
all_plot_yunits[k] = k2sc_yunit
else:
all_plot_labels[k] = ''
all_plot_series[k] = []
all_plot_xunits[k] = ''
all_plot_yunits[k] = ''
else:
# Then there aren't the expected number of extensions.
errcode = 4
except IOError:
errcode = 5
all_plot_labels[i] = ''
all_plot_series[i] = []
all_plot_xunits[i] = ''
all_plot_yunits[i] = ''
# Create the return DataSeries object.
return_dataseries = DataSeries('hlsp_k2sc', obsid, all_plot_series,
all_plot_labels,
all_plot_xunits, all_plot_yunits,
errcode)
else:
# This is where an error DataSeries object would be returned.
return_dataseries = DataSeries('hlsp_k2sc', obsid, [], [], [], [],
parsed_file_result.errcode)
# Return the DataSeries object back to the calling module.
return return_dataseries
#--------------------