-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathparse_obsid_hlsp_everest.py
77 lines (62 loc) · 2.78 KB
/
parse_obsid_hlsp_everest.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
"""
.. module:: parse_obsid_hlsp_everest
:synopsis: Given a EVEREST obsID returns the corresponding K2 target ID,
file name, cadence type, campaign, etc.
.. moduleauthor:: Scott W. Fleming <fleming@stsci.edu>
"""
import collections
import os
import re
#--------------------
def parse_obsid_hlsp_everest(obsid):
"""
Given a EVEREST observation ID, returns the file to read.
:param obsid: The EVEREST observation ID to retrieve the data from.
:type obsid: str
:returns: tuple -- An error code and a list of the set of files to read
(including paths).
Error codes:
0 = No error parsing observation ID.
1 = Error parsing EVEREST observation ID.
2 = Cadence not recognized as long cadence.
3 = File is missing on disk.
"""
# Create namedtuple as the return object.
parsed_values = collections.namedtuple('ParseResult', ['everestid',
'cadence',
'campaign',
'errcode', 'files'])
# Initialize error code to 0 = pass.
error_code = 0
# Split the observation ID into EVEREST star name, campaign, and cadence.
try:
everestid, campaign, cadence = [
x for x in re.split('everest|_|-', obsid) if x != '']
except ValueError:
error_code = 1
return parsed_values(everestid='', cadence='', campaign='',
errcode=error_code, files=[''])
# Make sure the cadence type is 'lc'.
if cadence != 'lc':
error_code = 2
return parsed_values(everestid=everestid, cadence=cadence,
campaign=campaign, errcode=error_code, files=[''])
# Use the observation ID to get paths to each file.
dir_root = (os.path.pardir + os.path.sep + os.path.pardir + os.path.sep +
"hlsps" + os.path.sep + "everest" +
os.path.sep +'v2' +os.path.sep + campaign + os.path.sep)
star_dir_root = (everestid[0:4] + "00000" + os.path.sep +
everestid[4:] + os.path.sep)
# Generate FITS file name based on observation ID.
file_name = ("hlsp_everest_k2_llc_"+ everestid +
"-" + campaign + "_kepler_v2.0_lc.fits")
full_file_name = dir_root + star_dir_root + file_name
if os.path.isfile(full_file_name):
return parsed_values(everestid=everestid, cadence=cadence,
campaign=campaign, errcode=error_code,
files=[full_file_name])
error_code = 3
return parsed_values(everestid=everestid, cadence=cadence,
campaign=campaign, errcode=error_code,
files=[full_file_name])
#--------------------