Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

update boss paths for v6_2+ #65

Merged
merged 14 commits into from
Nov 7, 2024
214 changes: 196 additions & 18 deletions python/sdss_access/path/path.py
Original file line number Diff line number Diff line change
Expand Up @@ -335,10 +335,22 @@ def extract(self, name, example):
template = re.sub('@healpixgrp[|]', '{healpixgrp}', template)
elif re.search('@configgrp[|]', template):
template = re.sub('@configgrp[|]', '{configgrp}', template)
elif re.search('@isplate[|]', template):
if re.search('@isplate[|]', template):
template = re.sub('@isplate[|]', '{isplate}', template)
elif re.search('@pad_fieldid[|]', template):
if re.search('@pad_fieldid[|]', template):
template = re.sub('@pad_fieldid[|]', '{fieldid}', template)
if re.search('@spcoaddfolder[|]',template):
template = re.sub('@spcoaddfolder[|]', '{spcoaddfolder}', template)
if re.search('@sptypefolder[|]',template):
template = re.sub('@sptypefolder[|]', '{sptypefolder}', template)
if re.search('@epochflag[|]', template):
template = re.sub('@epochflag[|]', '{epochflag}', template)
if re.search('@spcoaddobs[|]',template):
template = re.sub('@spcoaddobs[|]', '{obs}', template)
if re.search('@spcoaddgrp[|]',template):
template = re.sub('@spcoaddgrp[|]', '{spcoaddgrp}', template)
if re.search('@fieldgrp[|]',template):
template = re.sub('@fieldgrp[|]', '{fieldgrp}', template)
if re.search('@plateid6[|]', template):
template = re.sub('@plateid6[|]', '{plateid:0>6}', template)
if re.search('@component_default[|]', template):
Expand Down Expand Up @@ -386,12 +398,28 @@ def extract(self, name, example):
drval = re.match('^DR[1-9][0-9]', value).group(0)
otherval = value.split(drval)[-1]
pdict = {keys[0]: drval, keys[1]: otherval}
elif keys == ['fieldid','isplate']:
# for {fieldid}{isplate} as isplate is calculated automatically
if value.endswith('p') and value[:-1].isdigit():
value = value[:-1]
pdict = {keys[0]:value}
elif keys == ['run2d','epochflag']:
# for {run2d}{epochflag} as epochflag is calculated automatically
pdict = {keys[0]:value.replace('-epoch','')}
elif keys == ['coadd', 'obs']:
value = value.split('_')
if len(value) == 1:
value.append('')
pdict = {keys[0]: value[0], keys[1]: value[1]}
elif keys[0] in ['rc', 'br', 'filter', 'camrow']:
# for {camrow}{camcol}, {filter}{camcol}, {br}{id}, etc
pdict = {keys[0]: value[0], keys[1]: value[1:]}
else:
raise ValueError('This case has not yet been accounted for.')
path_dict.update(pdict)
elif keys[0] in ['sptypefolder','fieldgrp','spcoaddfolder','spcoaddgrp']:
# supress the keys since they are automatically calculated
continue
else:
path_dict[keys[0]] = value
return path_dict
Expand Down Expand Up @@ -1531,32 +1559,182 @@ def pad_fieldid(self, filetype, **kwargs):
return str(fieldid)
if fieldid.isnumeric():
return str(fieldid).zfill(6)
else:
return fieldid
return fieldid

def tilegrp(self, filetype, **kwargs):
''' Returns LVM tile id group subdirectory
def spcoaddfolder(self, filetype, **kwargs):
''' Returns the reorganized subfolder structure for the BOSS idlspec2d run2d version

Parameters
----------
---------
filetype : str
File type parameter.
tileid : int or str
LVM Tile ID number. Will be converted to int internally.
File type parameter
run2d : str
BOSS idlspec2d run2d version
coadd : str
Name of the custom coadd schema
Returns
-------
sptypefolder : str
'''

run2d = kwargs.get('run2d', None)
coaddname = kwargs.get('coadd', None)

if (not run2d):
return ''
if (('v5' in run2d) or (str(run2d) in ['26','103','104']) or
('v6_0' in run2d) or ('v6_1' in run2d)):
return ''
if filetype.lower() in ['spall_coadd','spall-lite_coadd','spallline_coadd']:
return 'summary'
if filetype.lower() in ['speclite_coadd','specfull_coadd',
'spallfield_coadd','spalllinefield_coadd']:
return coaddname
return('fields')
havok2063 marked this conversation as resolved.
Show resolved Hide resolved


def spcoaddgrp(self, filetype, **kwargs):
''' Returns the coadd group (field group analog) subfolder structure for the BOSS idlspec2d run2d version

Parameters
---------
filetype : str
File type parameter
run2d : str
BOSS idlspec2d run2d version
coadd : str
Name of the custom coadd schema
Returns
-------
tileidgrp : str
Tile ID group directory in the format ``NNNNXX``.
spcoaddgrp : str
'''
run2d = kwargs.get('run2d', None)
coaddname = kwargs.get('coadd', None)

if (not run2d):
return ''
if (('v5' in run2d) or (str(run2d) in ['26','103','104']) or
('v6_0' in run2d) or ('v6_1' in run2d)):
return ''
return coaddname

def sptypefolder(self, filetype, **kwargs):
''' Returns the reorganized subfolder structure for the BOSS idlspec2d run2d version

Parameters
---------
filetype : str
File type parameter
run2d : str
BOSS idlspec2d run2d version
Returns
-------
sptypefolder : str
'''

tileid = kwargs.get('tileid', None)
if not tileid:
return '0000XX'
elif '*' in str(tileid):
return '{0}XX'.format(tileid)
return '{:0>4d}XX'.format(int(tileid) // 1000)
run2d = kwargs.get('run2d', None)

if (not run2d) or ('v5' in run2d) or (str(run2d) in ['26','103','104']):
return ''
if ('v6_0' in run2d) or ('v6_1' in run2d):
if filetype.lower() in ['speclite_epoch','specfull_epoch',
'spallfield_epoch','spalllinefield_epoch']:
return 'epoch/spectra'
return 'epoch'
if filetype.lower() in ['fieldlist_epoch','spall_epoch',
'spall-lite_epoch','spallline_epoch']:
return 'summary/epoch'
if filetype.lower() in ['speclite_epoch','specfull_epoch',
'spallfield_epoch','spalllinefield_epoch']:
return 'spectra/epoch'
if filetype.lower() in ['conflist','fieldlist','spall',
'spall-lite','spallline']:
return 'summary/daily'
if filetype.lower() in ['speclite','specfull',
'spallfield','spalllinefield']:
return 'daily'
return 'fields'

def spcoaddobs(self, filetype, **kwargs):
''' Returns the formatted observatory flag for custom coadds for the BOSS idlspec2d

Parameters
----------
filetype : str
File type parameter
run2d : str
BOSS idlspec2d run2d version
obs : str
Observatory of observations: LCO, APO, ''(for merged)

Returns
-------
obs : str
'''

obs = kwargs.get('obs', None)
run2d = kwargs.get('run2d', None)

if not obs or obs == '':
return ''
if (('v5' in run2d) or (str(run2d) in ['26','103','104']) or
(('v6_0' in run2d) or ('v6_1' in run2d)) and obs.lower()) == 'apo':
return ''
if obs == '*':
return obs
return '_{}'.format(obs.lower())

def epochflag(self, filetype, **kwargs):
''' Returns the flag for epoch coadds for the BOSS idlspec2d

Parameters
----------
filetype : str
File type parameter
run2d : str
BOSS idlspec2d run2d version

Returns
-------
epochflag : str
'''

run2d = kwargs.get('run2d', None)
if (('v5' in run2d) or (str(run2d) in ['26','103','104']) or
('v6_0' in run2d) or ('v6_1' in run2d)):
return ''
return '-epoch'

def fieldgrp(self, filetype, **kwargs):
''' Returns the fieldid group for the BOSS idlspec2d run2d version

Parameters
---------
filetype : str
File type parameter
run2d : str
BOSS idlspec2d run2d version
fieldid : str or int
Field ID number. Will be converted to str internally.

Returns
-------
fieldgrp : str
'''

fieldid = kwargs.get('fieldid', None)
run2d = kwargs.get('run2d', None)

if (not fieldid):
return ''

if (('v5' in run2d) or (str(run2d) in ['26','103','104']) of
('v6_0' in run2d) or ('v6_1' in run2d)):
return ''
fieldid = str(fieldid)
if fieldid.isnumeric():
return '{:0>3d}XXX'.format(int(fieldid) // 1000)
return fieldid

class AccessError(Exception):
pass
20 changes: 15 additions & 5 deletions tests/path/test_sdss5.py
Original file line number Diff line number Diff line change
Expand Up @@ -59,12 +59,22 @@ def test_apogee_paths(self, path, name, special, keys, exp):
'v6_0_4/1234p/spFrame-b1-00005432.fits.gz'),
('spField', '@pad_fieldid', {'run2d': 'v6_1_1', 'mjd': '59630', 'fieldid': '*'},
'v6_1_1/*/spField-*-59630.fits'),
('lvm_frame', '@tilegrp', {'drpver': 'master', 'mjd': 60235,
'tileid': 1055360, 'kind': 'CFrame', 'expnum': 6817},
'1055XX/1055360/60235/lvmCFrame-00006817.fits')],
('spCOADDS','@spcoaddfolder',{'run2d':'v6_2_0','survey':'BHM','coadd':'allepoch','phase':'SDSSV'},
'v6_2_0/fields/SDSSV_BHM_COADDS.par'),
('spField','@sptypefolder',{'run2d':'v6_2_0','mjd': '59630', 'fieldid': '123456'},
'v6_2_0/fields/123XXX/123456/spField-123456-59630.fits'),
('spField','@fieldgrp',{'run2d':'v6_2_0','mjd': '59630', 'fieldid': '123456'},
'v6_2_0/fields/123XXX/123456/spField-123456-59630.fits'),
('spFullsky','@spcoaddobs',{'run2d':'v6_2_0','mjd': '59630','coadd':'allepoch','obs':'apo'},
'v6_2_0/fields/allepoch/allepoch_apo/spFullsky-allepoch_apo-59630.fits'),
('spAll_epoch','@epochflag',{'run2d':'v6_2_0'},
'v6_2_0/summary/epoch/spAll-v6_2_0-epsilon-epoch.fits.gz'),
('spAll_coadd','@spcoaddgrp',{'run2d':'v6_2_0','coadd':'allepoch'},
'v6_2_0/summary/test/spAll-v6_2_0-epsilon-allepoch.fits.gz')],
ids=['configgrp', 'apgprefix-apo', 'apgprefix-lco', 'apgprefix-ins',
'isplate-v6_0_4','pad_fieldid-5','pad_fieldid-6', 'frame-pad', 'frame-nopadp',
'pad_fieldid-*', 'lvm-tileid'])
'isplate-v6_0_4','pad_fieldid-5','pad_fieldid-6', 'frame-pad',
'frame-nopadp', 'pad_fieldid-*','spcoaddfolder', 'sptypefolder',
'fieldgrp','spcoaddobs','epochflag','spcoaddgrp'])
def test_special_function(self, path, name, special, keys, exp):
assert special in path.templates[name]
full = path.full(name, **keys)
Expand Down
Loading