Skip to content

Commit

Permalink
Rewrite coordinate systems tests for APE 14
Browse files Browse the repository at this point in the history
This highlights some API changes here.
  • Loading branch information
Cadair committed Jun 23, 2023
1 parent 448ae35 commit 846b0cf
Show file tree
Hide file tree
Showing 5 changed files with 160 additions and 108 deletions.
4 changes: 2 additions & 2 deletions gwcs/api.py
Original file line number Diff line number Diff line change
Expand Up @@ -256,11 +256,11 @@ def serialized_classes(self):

@property
def world_axis_object_classes(self):
return self.output_frame._world_axis_object_classes
return self.output_frame.world_axis_object_classes

Check warning on line 259 in gwcs/api.py

View check run for this annotation

Codecov / codecov/patch

gwcs/api.py#L259

Added line #L259 was not covered by tests

@property
def world_axis_object_components(self):
return self.output_frame._world_axis_object_components
return self.output_frame.world_axis_object_components

Check warning on line 263 in gwcs/api.py

View check run for this annotation

Codecov / codecov/patch

gwcs/api.py#L263

Added line #L263 was not covered by tests

@property
def pixel_axis_names(self):
Expand Down
64 changes: 32 additions & 32 deletions gwcs/coordinate_frames.py
Original file line number Diff line number Diff line change
Expand Up @@ -249,7 +249,7 @@ def axis_physical_types(self):

@property
@abc.abstractmethod
def _world_axis_object_classes(self):
def world_axis_object_classes(self):
"""
The APE 14 object classes for this frame.
Expand All @@ -260,7 +260,7 @@ def _world_axis_object_classes(self):

@property
@abc.abstractmethod
def _world_axis_object_components(self):
def world_axis_object_components(self):
"""
The APE 14 object components for this frame.
Expand Down Expand Up @@ -444,14 +444,14 @@ def axis_physical_types(self):
return self._axis_physical_types or self._default_axis_physical_types

@property
def _world_axis_object_classes(self):
def world_axis_object_classes(self):
return {f"{at}{i}" if i != 0 else at: (u.Quantity,
(),
{'unit': unit})
for i, (at, unit) in enumerate(zip(self._axes_type, self.unit))}

@property
def _world_axis_object_components(self):
def world_axis_object_components(self):
return [(f"{at}{i}" if i != 0 else at, 0, 'value') for i, at in enumerate(self._axes_type)]


Expand Down Expand Up @@ -519,15 +519,15 @@ def _default_axis_physical_types(self):
return tuple("custom:{}".format(t) for t in self.axes_names)

@property
def _world_axis_object_classes(self):
def world_axis_object_classes(self):
return {'celestial': (
coord.SkyCoord,
(),
{'frame': self.reference_frame,
'unit': self.unit})}

@property
def _world_axis_object_components(self):
def world_axis_object_components(self):
return [('celestial', 0, 'spherical.lon'),
('celestial', 1, 'spherical.lat')]

Expand Down Expand Up @@ -581,14 +581,14 @@ def _default_axis_physical_types(self):
return ("custom:{}".format(self.unit[0].physical_type),)

@property
def _world_axis_object_classes(self):
def world_axis_object_classes(self):
return {'spectral': (
coord.SpectralCoord,
(),
{'unit': self.unit[0]})}

@property
def _world_axis_object_components(self):
def world_axis_object_components(self):
return [('spectral', 0, 'value')]


Expand Down Expand Up @@ -633,8 +633,19 @@ def __init__(self, reference_frame, unit=None, axes_order=(0,),
def _default_axis_physical_types(self):
return ("time",)

def _convert_to_time(self, dt, *, unit, **kwargs):
if (not isinstance(dt, time.TimeDelta) and

Check warning on line 637 in gwcs/coordinate_frames.py

View check run for this annotation

Codecov / codecov/patch

gwcs/coordinate_frames.py#L637

Added line #L637 was not covered by tests
isinstance(dt, time.Time) or
isinstance(self.reference_frame.value, np.ndarray)):
return time.Time(dt, **kwargs)

Check warning on line 640 in gwcs/coordinate_frames.py

View check run for this annotation

Codecov / codecov/patch

gwcs/coordinate_frames.py#L640

Added line #L640 was not covered by tests

if not hasattr(dt, 'unit'):
dt = dt * unit

Check warning on line 643 in gwcs/coordinate_frames.py

View check run for this annotation

Codecov / codecov/patch

gwcs/coordinate_frames.py#L642-L643

Added lines #L642 - L643 were not covered by tests

return self.reference_frame + dt

Check warning on line 645 in gwcs/coordinate_frames.py

View check run for this annotation

Codecov / codecov/patch

gwcs/coordinate_frames.py#L645

Added line #L645 was not covered by tests

@property
def _world_axis_object_classes(self):
def world_axis_object_classes(self):
comp = (
time.Time,
(),
Expand All @@ -644,25 +655,14 @@ def _world_axis_object_classes(self):
return {'temporal': comp}

@property
def _world_axis_object_components(self):
def world_axis_object_components(self):
if isinstance(self.reference_frame.value, np.ndarray):
return [('temporal', 0, 'value')]

def offset_from_time_and_reference(time):
return (time - self.reference_frame).sec
return [('temporal', 0, offset_from_time_and_reference)]

def _convert_to_time(self, dt, *, unit, **kwargs):
if (not isinstance(dt, time.TimeDelta) and
isinstance(dt, time.Time) or
isinstance(self.reference_frame.value, np.ndarray)):
return time.Time(dt, **kwargs)

if not hasattr(dt, 'unit'):
dt = dt * unit

return self.reference_frame + dt


class CompositeFrame(CoordinateFrame):
"""
Expand Down Expand Up @@ -699,10 +699,10 @@ def __init__(self, frames, name=None):
"axes_order should contain unique numbers, "
"got {}.".format(axes_order))

super(CompositeFrame, self).__init__(naxes, axes_type=axes_type,
axes_order=axes_order,
unit=unit, axes_names=axes_names,
name=name)
super().__init__(naxes, axes_type=axes_type,

Check warning on line 702 in gwcs/coordinate_frames.py

View check run for this annotation

Codecov / codecov/patch

gwcs/coordinate_frames.py#L702

Added line #L702 was not covered by tests
axes_order=axes_order,
unit=unit, axes_names=axes_names,
name=name)
self._axis_physical_types = tuple(ph_type)

@property
Expand All @@ -719,7 +719,7 @@ def _wao_classes_rename_map(self):
for frame in self.frames:
# ensure the frame is in the mapper
mapper[frame]
for key in frame._world_axis_object_classes.keys():
for key in frame.world_axis_object_classes.keys():

Check warning on line 722 in gwcs/coordinate_frames.py

View check run for this annotation

Codecov / codecov/patch

gwcs/coordinate_frames.py#L722

Added line #L722 was not covered by tests
if key in seen_names:
new_key = f"{key}{seen_names.count(key)}"
mapper[frame][key] = new_key
Expand All @@ -731,7 +731,7 @@ def _wao_renamed_components_iter(self):
mapper = self._wao_classes_rename_map
for frame in self.frames:
renamed_components = []
for comp in frame._world_axis_object_components:
for comp in frame.world_axis_object_components:

Check warning on line 734 in gwcs/coordinate_frames.py

View check run for this annotation

Codecov / codecov/patch

gwcs/coordinate_frames.py#L734

Added line #L734 was not covered by tests
comp = list(comp)
rename = mapper[frame].get(comp[0])
if rename:
Expand All @@ -743,14 +743,14 @@ def _wao_renamed_components_iter(self):
def _wao_renamed_classes_iter(self):
mapper = self._wao_classes_rename_map
for frame in self.frames:
for key, value in frame._world_axis_object_classes.items():
for key, value in frame.world_axis_object_classes.items():

Check warning on line 746 in gwcs/coordinate_frames.py

View check run for this annotation

Codecov / codecov/patch

gwcs/coordinate_frames.py#L746

Added line #L746 was not covered by tests
rename = mapper[frame].get(key)
if rename:
key = rename
yield key, value

@property
def _world_axis_object_components(self):
def world_axis_object_components(self):
"""
We need to generate the components respecting the axes_order.
"""
Expand All @@ -764,7 +764,7 @@ def _world_axis_object_components(self):
return out

@property
def _world_axis_object_classes(self):
def world_axis_object_classes(self):
return dict(self._wao_renamed_classes_iter)


Expand All @@ -790,15 +790,15 @@ def _default_axis_physical_types(self):
return ("phys.polarization.stokes",)

@property
def _world_axis_object_classes(self):
def world_axis_object_classes(self):
return {'stokes': (
StokesCoord,
(),
{},
)}

@property
def _world_axis_object_components(self):
def world_axis_object_components(self):
return [('stokes', 0, 'value')]


Expand Down
4 changes: 2 additions & 2 deletions gwcs/tests/test_api.py
Original file line number Diff line number Diff line change
Expand Up @@ -491,12 +491,12 @@ def test_composite_many_base_frame():
q_frame_2 = cf.CoordinateFrame(name='distance', axes_order=(1,), naxes=1, axes_type="SPATIAL", unit=(u.m,))
frame = cf.CompositeFrame([q_frame_1, q_frame_2])

wao_classes = frame._world_axis_object_classes
wao_classes = frame.world_axis_object_classes

assert len(wao_classes) == 2
assert not set(wao_classes.keys()).difference({"SPATIAL", "SPATIAL1"})

wao_components = frame._world_axis_object_components
wao_components = frame.world_axis_object_components

assert len(wao_components) == 2
assert not {c[0] for c in wao_components}.difference({"SPATIAL", "SPATIAL1"})
Expand Down
Loading

0 comments on commit 846b0cf

Please sign in to comment.