Skip to content

Commit

Permalink
Plumbed name through headeronly data types.
Browse files Browse the repository at this point in the history
  • Loading branch information
cmccully committed Nov 10, 2023
1 parent 3acc932 commit 08ec49a
Show file tree
Hide file tree
Showing 5 changed files with 11 additions and 11 deletions.
4 changes: 2 additions & 2 deletions banzai/data.py
Original file line number Diff line number Diff line change
Expand Up @@ -85,8 +85,8 @@ def to_fits(self, context) -> Union[fits.HDUList, list]:


class HeaderOnly(Data):
def __init__(self, meta: Union[dict, fits.Header]):
super().__init__(data=np.zeros(0), meta=meta, memmap=False)
def __init__(self, meta: Union[dict, fits.Header], name):
super().__init__(data=np.zeros(0), meta=meta, memmap=False, name=name)

def to_fits(self, context):
return fits.HDUList([fits.ImageHDU(data=None, header=self.meta)])
Expand Down
6 changes: 3 additions & 3 deletions banzai/lco.py
Original file line number Diff line number Diff line change
Expand Up @@ -412,7 +412,7 @@ def open(self, file_info, runtime_context) -> Optional[ObservationFrame]:
for hdu in fits_hdu_list if hdu.data is not None):
for hdu in fits_hdu_list:
if hdu.data is None or hdu.data.size == 0:
hdu_list.append(HeaderOnly(meta=hdu.header))
hdu_list.append(HeaderOnly(meta=hdu.header, name=hdu.header.get('EXTNAME')))
else:
hdu_list.append(self.data_class(data=hdu.data, meta=hdu.header, name=hdu.header.get('EXTNAME')))
else:
Expand All @@ -424,7 +424,7 @@ def open(self, file_info, runtime_context) -> Optional[ObservationFrame]:
continue
# Otherwise parse the fits file into a frame object and the corresponding data objects
if hdu.data is None or hdu.data.size == 0:
hdu_list.append(HeaderOnly(meta=hdu.header))
hdu_list.append(HeaderOnly(meta=hdu.header, name=hdu.header.get('EXTNAME')))
primary_hdu = hdu
elif isinstance(hdu, fits.BinTableHDU):
hdu_list.append(DataTable(data=Table(hdu.data), meta=hdu.header, name=hdu.header.get('EXTNAME')))
Expand Down Expand Up @@ -601,7 +601,7 @@ def _munge_data_cube(hdu):
:return: List CCDData objects
"""
# The first extension gets to be a header only object
hdu_list = [HeaderOnly(meta=hdu.header)]
hdu_list = [HeaderOnly(meta=hdu.header, name=hdu.header.get('EXTNAME'))]

# We need to properly set the datasec and detsec keywords in case we didn't read out the
# middle row (the "Missing Row Problem").
Expand Down
6 changes: 3 additions & 3 deletions banzai/tests/test_munge.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ def test_when_has_partial_coefficients():
for i in range(2):
for j in range(2):
header['CRSTLK{i}{j}'.format(i=i+1, j=j+1)] = 1.0
hdu_list = [HeaderOnly(meta=header)] + [FakeCCDData() for i in range(4)]
hdu_list = [HeaderOnly(meta=header, name='')] + [FakeCCDData() for i in range(4)]
with pytest.raises(MissingCrosstalkCoefficients):
LCOFrameFactory._init_crosstalk(FakeLCOObservationFrame(hdu_list=hdu_list))

Expand All @@ -34,7 +34,7 @@ def test_when_has_coefficients():
for i in range(4):
for j in range(4):
header['CRSTLK{i}{j}'.format(i=i+1, j=j+1)] = 1.0
hdu_list = [HeaderOnly(meta=header)] + [FakeCCDData() for i in range(4)]
hdu_list = [HeaderOnly(meta=header, name='')] + [FakeCCDData() for i in range(4)]
LCOFrameFactory._init_crosstalk(FakeLCOObservationFrame(hdu_list=hdu_list))


Expand All @@ -44,7 +44,7 @@ def test_defaults_do_not_override_header():
for j in range(4):
header['CRSTLK{i}{j}'.format(i=i+1, j=j+1)] = 1.0

hdu_list = [HeaderOnly(meta=header)] + [FakeCCDData() for i in range(4)]
hdu_list = [HeaderOnly(meta=header, name='')] + [FakeCCDData() for i in range(4)]
fake_image = FakeLCOObservationFrame(hdu_list=hdu_list)
LCOFrameFactory._init_crosstalk(fake_image)

Expand Down
4 changes: 2 additions & 2 deletions banzai/tests/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -102,8 +102,8 @@ def handles_inhomogeneous_set(stagetype, context, keyword, value, calibration_ma
stage = stagetype(context)
kwargs = {keyword: value}
if calibration_maker:
images = [LCOCalibrationFrame(hdu_list=[HeaderOnly(meta=kwargs)])]
images += [LCOCalibrationFrame(hdu_list=[HeaderOnly()]) for x in range(6)]
images = [LCOCalibrationFrame(hdu_list=[HeaderOnly(meta=kwargs, name='')])]
images += [LCOCalibrationFrame(hdu_list=[HeaderOnly(meta={}, name=''),]) for x in range(6)]
images = stage.do_stage(images)
assert len(images) == 0
else:
Expand Down
2 changes: 1 addition & 1 deletion banzai/utils/realtime_utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -84,7 +84,7 @@ def need_to_process_image(file_info, context):
if 'frameid' in file_info:
try:
factory = import_utils.import_attribute(context.FRAME_FACTORY)()
test_image = factory.observation_frame_class(hdu_list=[HeaderOnly(file_info)],
test_image = factory.observation_frame_class(hdu_list=[HeaderOnly(file_info, name='')],
file_path=file_info['filename'])
test_image.instrument = factory.get_instrument_from_header(file_info, db_address=context.db_address)
if image_utils.get_reduction_level(test_image.meta) != '00':
Expand Down

0 comments on commit 08ec49a

Please sign in to comment.