Skip to content

Commit

Permalink
Add consistency checking for fhd files
Browse files Browse the repository at this point in the history
  • Loading branch information
bhazelton committed Nov 13, 2023
1 parent c77afdc commit 4c90e27
Show file tree
Hide file tree
Showing 26 changed files with 584 additions and 506 deletions.
18 changes: 9 additions & 9 deletions docs/uvcal_tutorial.rst
Original file line number Diff line number Diff line change
Expand Up @@ -148,10 +148,10 @@ b) FHD cal to cal fits
>>> import os
>>> from pyuvdata import UVCal
>>> from pyuvdata.data import DATA_PATH
>>> obs_testfile = os.path.join(DATA_PATH, 'fhd_cal_data/1061316296_obs.sav')
>>> cal_testfile = os.path.join(DATA_PATH, 'fhd_cal_data/1061316296_cal.sav')
>>> settings_testfile = os.path.join(DATA_PATH, 'fhd_cal_data/1061316296_settings.txt')
>>> layout_testfile = os.path.join(DATA_PATH, 'fhd_cal_data/1061316296_layout.sav')
>>> obs_testfile = os.path.join(DATA_PATH, 'fhd_cal_data/metadata/1061316296_obs.sav')
>>> cal_testfile = os.path.join(DATA_PATH, 'fhd_cal_data/calibration/1061316296_cal.sav')
>>> settings_testfile = os.path.join(DATA_PATH, 'fhd_cal_data/metadata/1061316296_settings.txt')
>>> layout_testfile = os.path.join(DATA_PATH, 'fhd_cal_data/metadata/1061316296_layout.sav')
>>> # Here we use the ``from_file`` class method, can also use the ``read`` method.
>>> # Can optionally specify the ``file_type`` to either method
Expand Down Expand Up @@ -499,20 +499,20 @@ with the previous file(s).
>>> # For FHD cal datasets pass lists for each file type
>>> obs_testfiles = [
... os.path.join(DATA_PATH, 'fhd_cal_data/1061316296_obs.sav'),
... os.path.join(DATA_PATH, 'fhd_cal_data/metadata/1061316296_obs.sav'),
... os.path.join(DATA_PATH, 'fhd_cal_data/set2/1061316296_obs.sav'),
... ]
>>> cal_testfiles = [
... os.path.join(DATA_PATH, 'fhd_cal_data/1061316296_cal.sav'),
... os.path.join(DATA_PATH, 'fhd_cal_data/calibration/1061316296_cal.sav'),
... os.path.join(DATA_PATH, 'fhd_cal_data/set2/1061316296_cal.sav'),
... ]
>>> settings_testfiles = [
... os.path.join(DATA_PATH, 'fhd_cal_data/1061316296_settings.txt'),
... os.path.join(DATA_PATH, 'fhd_cal_data/metadata/1061316296_settings.txt'),
... os.path.join(DATA_PATH, 'fhd_cal_data/set2/1061316296_settings.txt'),
... ]
>>> layout_testfiles = [
... os.path.join(DATA_PATH, 'fhd_cal_data/1061316296_layout.sav'),
... os.path.join(DATA_PATH, 'fhd_cal_data/1061316296_layout.sav'),
... os.path.join(DATA_PATH, 'fhd_cal_data/metadata/1061316296_layout.sav'),
... os.path.join(DATA_PATH, 'fhd_cal_data/metadata/1061316296_layout.sav'),
... ]
>>> fhd_cal = UVCal.from_file(
... cal_testfiles,
Expand Down
33 changes: 21 additions & 12 deletions docs/uvdata_tutorial.rst
Original file line number Diff line number Diff line change
Expand Up @@ -145,16 +145,20 @@ When reading FHD format, we need to point to several files for each observation.
>>> uvd = UVData()
>>> # Construct the list of files
>>> fhd_prefix = os.path.join(DATA_PATH, 'fhd_vis_data/1061316296_')
>>> fhd_vis_files = [fhd_prefix + f for f in ['vis_XX.sav', 'vis_YY.sav']]
>>> fhd_prefix = '1061316296_'
>>> fhd_vis_files = [os.path.join(DATA_PATH, 'fhd_vis_data', 'vis_data', fhd_prefix + f) for f in ['vis_XX.sav', 'vis_YY.sav']]
>>> flags_file = os.path.join(DATA_PATH, 'fhd_vis_data', 'vis_data', fhd_prefix + 'flags.sav')
>>> layout_file = os.path.join(DATA_PATH, 'fhd_vis_data', 'metadata', fhd_prefix + 'layout.sav')
>>> params_file = os.path.join(DATA_PATH, 'fhd_vis_data', 'metadata', fhd_prefix + 'params.sav')
>>> settings_file = os.path.join(DATA_PATH, 'fhd_vis_data', 'metadata', fhd_prefix + 'settings.txt')
# Use the `read` or `from_file` method, optionally specify the file type.
>>> uvd = UVData.from_file(
... fhd_vis_files,
... params_file=fhd_prefix + 'params.sav',
... flag_file=fhd_prefix + 'flags.sav',
... layout_file=fhd_prefix + 'layout.sav',
... settings_file=fhd_prefix + 'settings.txt',
... flags_file=flags_file,
... layout_file=layout_file,
... params_file=params_file,
... settings_file=settings_file,
... use_future_array_shapes=True
... )
>>> write_file = os.path.join('.', 'tutorial.uvfits')
Expand All @@ -171,16 +175,21 @@ d) FHD -> miriad
>>> import os
>>> # Construct the list of files
>>> fhd_prefix = os.path.join(DATA_PATH, 'fhd_vis_data/1061316296_')
>>> fhd_vis_files = [fhd_prefix + f for f in ['vis_XX.sav', 'vis_YY.sav']]
>>> fhd_prefix = '1061316296_'
>>> fhd_vis_files = [os.path.join(DATA_PATH, 'fhd_vis_data', 'vis_data', fhd_prefix + f) for f in ['vis_XX.sav', 'vis_YY.sav']]
>>> flags_file = os.path.join(DATA_PATH, 'fhd_vis_data', 'vis_data', fhd_prefix + 'flags.sav')
>>> layout_file = os.path.join(DATA_PATH, 'fhd_vis_data', 'metadata', fhd_prefix + 'layout.sav')
>>> params_file = os.path.join(DATA_PATH, 'fhd_vis_data', 'metadata', fhd_prefix + 'params.sav')
>>> settings_file = os.path.join(DATA_PATH, 'fhd_vis_data', 'metadata', fhd_prefix + 'settings.txt')
# Use the `read` or `from_file` method, optionally specify the file type.
>>> uvd = UVData.from_file(
... fhd_vis_files,
... params_file=fhd_prefix + 'params.sav',
... flag_file=fhd_prefix + 'flags.sav',
... layout_file=fhd_prefix + 'layout.sav',
... settings_file=fhd_prefix + 'settings.txt',
... flags_file=flags_file,
... layout_file=layout_file,
... params_file=params_file,
... settings_file=settings_file,
... use_future_array_shapes=True
... )
>>> write_file = os.path.join('.','tutorial.uv')
Expand Down
20 changes: 9 additions & 11 deletions pyuvdata/uvcal/fhd_cal.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@

from .. import utils as uvutils
from ..docstrings import copy_replace_short_description
from ..uvdata.fhd import get_fhd_history, get_fhd_layout_info
from ..uvdata.fhd import fhd_filenames, get_fhd_history, get_fhd_layout_info
from .uvcal import UVCal, _future_array_shapes_warning

__all__ = ["FHDCal"]
Expand Down Expand Up @@ -49,16 +49,14 @@ def read_fhd_cal(
if not read_data and settings_file is None:
raise ValueError("A settings_file must be provided if read_data is False.")

filelist = [cal_file, obs_file]
if layout_file is not None:
filelist.append(layout_file)
if settings_file is not None:
filelist.append(settings_file)
for filename in filelist:
# update filelist
basename = os.path.basename(filename)
self.filename = uvutils._combine_filenames(self.filename, [basename])
self._filename.form = (len(self.filename),)
filenames = fhd_filenames(
obs_file=obs_file,
layout_file=layout_file,
settings_file=settings_file,
cal_file=cal_file,
)
self.filename = filenames
self._filename.form = (len(self.filename),)

this_dict = readsav(obs_file, python_dict=True)
obs_data = this_dict["obs"]
Expand Down
125 changes: 91 additions & 34 deletions pyuvdata/uvcal/tests/test_fhd_cal.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,13 +16,13 @@
# set up FHD files
testdir = os.path.join(DATA_PATH, "fhd_cal_data/")
testfile_prefix = "1061316296_"
obs_testfile = os.path.join(testdir, testfile_prefix + "obs.sav")
cal_testfile = os.path.join(testdir, testfile_prefix + "cal.sav")
settings_testfile = os.path.join(testdir, testfile_prefix + "settings.txt")
obs_testfile = os.path.join(testdir, "metadata", testfile_prefix + "obs.sav")
cal_testfile = os.path.join(testdir, "calibration", testfile_prefix + "cal.sav")
settings_testfile = os.path.join(testdir, "metadata", testfile_prefix + "settings.txt")
settings_testfile_nodiffuse = os.path.join(
testdir, testfile_prefix + "nodiffuse_settings.txt"
)
layout_testfile = os.path.join(testdir, testfile_prefix + "layout.sav")
layout_testfile = os.path.join(testdir, "metadata", testfile_prefix + "layout.sav")

testdir2 = os.path.join(DATA_PATH, "fhd_cal_data/set2")
obs_file_multi = [obs_testfile, os.path.join(testdir2, testfile_prefix + "obs.sav")]
Expand All @@ -48,8 +48,8 @@ def test_read_fhdcal_write_read_calfits(raw, fhd_cal_raw, fhd_cal_fit, tmp_path)
fhd_cal = fhd_cal_fit

filelist = [cal_testfile, obs_testfile, layout_testfile, settings_testfile]
assert set(fhd_cal.filename) == {os.path.basename(fn) for fn in filelist}

assert fhd_cal.filename == sorted(os.path.basename(file) for file in filelist)
assert np.max(fhd_cal.gain_array) < 2.0

outfile = str(tmp_path / "outtest_FHDcal_1061311664.calfits")
Expand Down Expand Up @@ -109,48 +109,86 @@ def test_read_fhdcal_metadata(raw, fhd_cal_raw, fhd_cal_fit):

# test that no diffuse is properly picked up from the settings file when
# read_data is False
fhd_cal = UVCal.from_file(
cal_testfile,
obs_file=obs_testfile,
layout_file=layout_testfile,
settings_file=settings_testfile_nodiffuse,
raw=raw,
read_data=False,
use_future_array_shapes=True,
)
with uvtest.check_warnings(
UserWarning,
match=[
"Some FHD input files do not have the expected subfolder so FHD folder "
"matching could not be done. The affected file types are: ['settings']",
"The FHD input files do not all have matching prefixes, so they may not be "
"for the same data.",
"Telescope location derived from obs lat/lon/alt values does not match the "
"location in the layout file. Using the value from known_telescopes.",
],
):
fhd_cal = UVCal.from_file(
cal_testfile,
obs_file=obs_testfile,
layout_file=layout_testfile,
settings_file=settings_testfile_nodiffuse,
raw=raw,
read_data=False,
use_future_array_shapes=True,
)

assert fhd_cal.diffuse_model is None

return


@pytest.mark.filterwarnings("ignore:Telescope location derived from obs lat/lon/alt")
def test_read_fhdcal_multimode():
"""
Read cal with multiple mode_fit values.
"""
fhd_cal = UVCal.from_file(
os.path.join(testdir, testfile_prefix + "multimode_cal.sav"),
obs_file=obs_testfile,
layout_file=layout_testfile,
settings_file=os.path.join(testdir, testfile_prefix + "multimode_settings.txt"),
raw=False,
use_future_array_shapes=True,
)
with uvtest.check_warnings(
UserWarning,
match=[
"Some FHD input files do not have the expected subfolder so FHD folder "
"matching could not be done. The affected file types are: "
"['cal', 'settings']",
"The FHD input files do not all have matching prefixes, so they may not be "
"for the same data.",
"Telescope location derived from obs lat/lon/alt values does not match the "
"location in the layout file. Using the value from known_telescopes.",
],
):
fhd_cal = UVCal.from_file(
os.path.join(testdir, testfile_prefix + "multimode_cal.sav"),
obs_file=obs_testfile,
layout_file=layout_testfile,
settings_file=os.path.join(
testdir, testfile_prefix + "multimode_settings.txt"
),
raw=False,
use_future_array_shapes=True,
)
assert fhd_cal.extra_keywords["MODE_FIT"] == "[90, 150, 230, 320, 400, 524]"

fhd_cal2 = fhd_cal.copy(metadata_only=True)

# check metadata only read
fhd_cal = UVCal.from_file(
os.path.join(testdir, testfile_prefix + "multimode_cal.sav"),
obs_file=obs_testfile,
layout_file=layout_testfile,
settings_file=os.path.join(testdir, testfile_prefix + "multimode_settings.txt"),
raw=False,
read_data=False,
use_future_array_shapes=True,
)
with uvtest.check_warnings(
UserWarning,
match=[
"Some FHD input files do not have the expected subfolder so FHD folder "
"matching could not be done. The affected file types are: "
"['cal', 'settings']",
"The FHD input files do not all have matching prefixes, so they may not be "
"for the same data.",
"Telescope location derived from obs lat/lon/alt values does not match the "
"location in the layout file. Using the value from known_telescopes.",
],
):
fhd_cal = UVCal.from_file(
os.path.join(testdir, testfile_prefix + "multimode_cal.sav"),
obs_file=obs_testfile,
layout_file=layout_testfile,
settings_file=os.path.join(
testdir, testfile_prefix + "multimode_settings.txt"
),
raw=False,
read_data=False,
use_future_array_shapes=True,
)
# this file set has a mismatch in Nsources between the cal file & settings
# file for some reason. I think it's just an issue with the files chosen
assert fhd_cal.Nsources != fhd_cal2.Nsources
Expand Down Expand Up @@ -213,6 +251,9 @@ def test_flags_galaxy(tmp_path):
match=[
"tile_names from obs structure does not match",
"Telescope location derived from obs lat/lon/alt",
"Some FHD input files do not have the expected subfolder so FHD folder "
"matching could not be done. The affected file types are: ['cal', "
"'layout', 'obs', 'settings']",
],
):
fhd_cal = UVCal.from_file(
Expand All @@ -235,6 +276,10 @@ def test_unknown_telescope():
match=[
"Telescope foo is not in known_telescopes.",
"Telescope location derived from obs lat/lon/alt",
"Some FHD input files do not have the expected subfolder so FHD folder "
"matching could not be done. The affected file types are: ['obs']",
"The FHD input files do not all have matching prefixes, so they may not be "
"for the same data.",
],
):
fhd_cal = UVCal.from_file(
Expand Down Expand Up @@ -275,6 +320,10 @@ def test_break_read_fhdcal(cal_file, obs_file, layout_file, settings_file, nfile
if nfiles > 1:
message_list *= 2
message_list.append("UVParameter diffuse_model does not match")
message_list.append(
"Some FHD input files do not have the expected subfolder so FHD folder "
"matching could not be done. The affected file types are: ['cal', 'obs']"
)

with uvtest.check_warnings(UserWarning, message_list):
fhd_cal = UVCal.from_file(
Expand All @@ -299,12 +348,17 @@ def test_break_read_fhdcal(cal_file, obs_file, layout_file, settings_file, nfile
warning_list = [UserWarning] * (3 * nfiles - 1)

if nfiles > 1:
warning_list += [DeprecationWarning]
warning_list += [DeprecationWarning, UserWarning]
message_list += [
"Reading multiple files from file specific read methods is deprecated. Use "
"the generic `UVCal.read` method instead. This will become an error in "
"version 2.5"
]
message_list.append(
"Some FHD input files do not have the expected subfolder so FHD folder "
"matching could not be done. The affected file types are: "
"['cal', 'obs', 'settings']"
)

with uvtest.check_warnings(warning_list, match=message_list):
fhd_cal.read_fhd_cal(
Expand Down Expand Up @@ -338,13 +392,16 @@ def test_break_read_fhdcal(cal_file, obs_file, layout_file, settings_file, nfile
)
def test_read_multi(tmp_path, concat_method, read_method):
"""Test reading in multiple files."""
warn_type = [UserWarning] * 3
warn_type = [UserWarning] * 4
msg = [
"UVParameter diffuse_model does not match",
"Telescope location derived from obs lat/lon/alt values does not match the "
"location in the layout file.",
"Telescope location derived from obs lat/lon/alt values does not match the "
"location in the layout file.",
"Some FHD input files do not have the expected subfolder so FHD folder "
"matching could not be done. The affected file types are: "
"['cal', 'obs', 'settings']",
]

if concat_method == "fast_concat":
Expand Down
Loading

0 comments on commit 4c90e27

Please sign in to comment.