From 7e9e9fb0f59911acd920fc155a405df8db047342 Mon Sep 17 00:00:00 2001 From: David Hassell Date: Tue, 26 Mar 2024 09:50:40 +0000 Subject: [PATCH] 1-d Z Cartesian regridding fix and test --- cf/field.py | 7 +++++-- cf/regrid/regrid.py | 5 ++--- cf/test/test_regrid.py | 15 +++++++++++++++ 3 files changed, 22 insertions(+), 5 deletions(-) diff --git a/cf/field.py b/cf/field.py index 7efe404212..3f37b4843d 100644 --- a/cf/field.py +++ b/cf/field.py @@ -454,8 +454,11 @@ def __getitem__(self, indices): # below. if org_cyclic: new_cyclic = new_data.cyclic() - [new.cyclic(i, iscyclic=False) for i in org_cyclic if i not in new_cyclic] - + [ + new.cyclic(i, iscyclic=False) + for i in org_cyclic + if i not in new_cyclic + ] # ------------------------------------------------------------ # Subspace constructs with data diff --git a/cf/regrid/regrid.py b/cf/regrid/regrid.py index 4523072e56..59ee676289 100644 --- a/cf/regrid/regrid.py +++ b/cf/regrid/regrid.py @@ -988,14 +988,14 @@ def Cartesian_coords_to_domain(dst, dst_z=None, domain_class=None): if dst_z is not None: # Check that there are vertical coordinates, and replace - # 'dst_z' with its construct identifier. + # 'dst_z' with the identifier of its domain axis construct. z_key = d.coordinate(dst_z, key=True, default=None) if z_key is None: raise ValueError( f"Could not find destination {dst_z!r} vertical coordinates" ) - dst_z = z_key + dst_z = d.get_data_axes(z_key)[0] return d, axis_keys, dst_z @@ -2112,7 +2112,6 @@ def create_esmpy_grid(grid, mask=None): # masked/unmasked elements. grid_mask[...] = np.invert(mask).astype("int32") - # print(esmpy_grid) return esmpy_grid diff --git a/cf/test/test_regrid.py b/cf/test/test_regrid.py index fc429f2483..e3cfaa9b8f 100644 --- a/cf/test/test_regrid.py +++ b/cf/test/test_regrid.py @@ -157,6 +157,10 @@ class RegridTest(unittest.TestCase): dst = dst_src[0] src = dst_src[1] + filename_xyz = os.path.join( + os.path.dirname(os.path.abspath(__file__)), "regrid_xyz.nc" + ) + @unittest.skipUnless(esmpy_imported, "Requires esmpy/ESMF package.") def test_Field_regrid_2d_field(self): """2-d regridding with Field destination grid.""" @@ -735,6 +739,17 @@ def test_Field_regridc_1d_field(self): with self.assertRaises(ValueError): src.regridc(dst, method=method, axes=axes) + @unittest.skipUnless(esmpy_imported, "Requires esmpy/ESMF package.") + def test_Field_regridc_1d_coordinates_z(self): + """1-d Z Cartesian regridding with coordinates destination grid.""" + src = cf.read(self.filename_xyz)[0] + dst = cf.DimensionCoordinate( + data=cf.Data([800, 705, 632, 510, 320.0], "hPa") + ) + d = src.regridc([dst], method="linear", axes="Z", z="Z", ln_z=True) + z = d.dimension_coordinate("Z") + self.assertTrue(z.data.equals(dst.data)) + @unittest.skipUnless(esmpy_imported, "Requires esmpy/ESMF package.") def test_Field_regrid_chunks(self): """Regridding of chunked axes"""