From 745c4131ce939ad4442011d3991b82b6ac7c253c Mon Sep 17 00:00:00 2001 From: zacharyburnett Date: Thu, 18 Jul 2024 10:34:56 -0400 Subject: [PATCH 1/2] replace usages of ``copy_arrays`` with ``memmap`` for ``asdf>=3.1.0`` replace usages of ``copy_arrays`` with ``memmap`` --- CHANGES.rst | 1 + gwcs/tests/test_wcs.py | 19 ++++++++++++++----- gwcs/wcs.py | 2 +- 3 files changed, 16 insertions(+), 6 deletions(-) diff --git a/CHANGES.rst b/CHANGES.rst index d58150c5..c506eec6 100644 --- a/CHANGES.rst +++ b/CHANGES.rst @@ -1,6 +1,7 @@ 0.22.0 (unreleased) ------------------- +- replace usages of ``copy_arrays`` with ``memmap`` [#503] 0.21.0 (2024-03-10) ------------------- diff --git a/gwcs/tests/test_wcs.py b/gwcs/tests/test_wcs.py index 77627176..f78c0ed8 100644 --- a/gwcs/tests/test_wcs.py +++ b/gwcs/tests/test_wcs.py @@ -1,4 +1,5 @@ # Licensed under a 3-clause BSD style license - see LICENSE.rst +import importlib.metadata import warnings import os.path @@ -50,6 +51,14 @@ y = np.linspace(0, 1, ny) xv, yv = np.meshgrid(x, y) + +def asdf_open_memory_mapping_kwarg(memmap: bool) -> dict: + if tuple(int(part) for part in importlib.metadata.version("asdf").split(".")) >= (3, 1, 0): + return {"memmap": memmap} + else : + return {"copy_arrays": not memmap} + + # Test initializing a WCS @@ -648,7 +657,7 @@ def test_to_fits_sip(): xflat = np.ravel(x[1:-1, 1:-1]) yflat = np.ravel(y[1:-1, 1:-1]) fn = os.path.join(data_path, 'miriwcs.asdf') - with asdf.open(fn, lazy_load=False, copy_arrays=True, ignore_missing_extensions=True) as af: + with asdf.open(fn, lazy_load=False, ignore_missing_extensions=True, **asdf_open_memory_mapping_kwarg(memmap=False)) as af: miriwcs = af.tree['wcs'] bounding_box = ((0, 1024), (0, 1024)) mirisip = miriwcs.to_fits_sip(bounding_box, max_inv_pix_error=0.1, verbose=True) @@ -1009,7 +1018,7 @@ def test_to_fits_tab_time_cube(gwcs_cube_with_separable_time): def test_to_fits_tab_miri_image(): # gWCS: fn = os.path.join(data_path, 'miriwcs.asdf') - with asdf.open(fn, copy_arrays=True, lazy_load=False, ignore_missing_extensions=True) as af: + with asdf.open(fn, lazy_load=False, ignore_missing_extensions=True, **asdf_open_memory_mapping_kwarg(memmap=False)) as af: w = af.tree['wcs'] # FITS WCS -TAB: @@ -1033,7 +1042,7 @@ def test_to_fits_tab_miri_image(): def test_to_fits_tab_miri_lrs(): fn = os.path.join(data_path, 'miri_lrs_wcs.asdf') - with asdf.open(fn, copy_arrays=True, lazy_load=False, ignore_missing_extensions=True) as af: + with asdf.open(fn, lazy_load=False, ignore_missing_extensions=True, **asdf_open_memory_mapping_kwarg(memmap=False)) as af: w = af.tree['wcs'] # FITS WCS -TAB: @@ -1102,7 +1111,7 @@ def test_in_image(): def test_iter_inv(): fn = os.path.join(data_path, 'nircamwcs.asdf') - with asdf.open(fn, lazy_load=False, copy_arrays=False, ignore_missing_extensions=True) as af: + with asdf.open(fn, lazy_load=False, ignore_missing_extensions=True, **asdf_open_memory_mapping_kwarg(memmap=True)) as af: w = af.tree['wcs'] # remove analytic/user-supplied inverse: w.pipeline[0].transform.inverse = None @@ -1129,7 +1138,7 @@ def test_iter_inv(): ) assert np.allclose((x, y), (xp, yp)) - with asdf.open(fn, lazy_load=False, copy_arrays=False, ignore_missing_extensions=True) as af: + with asdf.open(fn, lazy_load=False, ignore_missing_extensions=True, **asdf_open_memory_mapping_kwarg(memmap=True)) as af: w = af.tree['wcs'] # test single point diff --git a/gwcs/wcs.py b/gwcs/wcs.py index 0432e541..62173532 100644 --- a/gwcs/wcs.py +++ b/gwcs/wcs.py @@ -679,7 +679,7 @@ def numerical_inverse(self, *args, tolerance=1e-5, maxiter=50, adaptive=True, >>> import numpy as np >>> filename = get_pkg_data_filename('data/nircamwcs.asdf', package='gwcs.tests') - >>> with asdf.open(filename, copy_arrays=True, lazy_load=False, ignore_missing_extensions=True) as af: + >>> with asdf.open(filename, memmap=False, lazy_load=False, ignore_missing_extensions=True) as af: ... w = af.tree['wcs'] >>> ra, dec = w([1,2,3], [1,1,1]) From 6ac17df7d76fa7a3dccb35c1abe79e2ba9f45d39 Mon Sep 17 00:00:00 2001 From: zacharyburnett Date: Fri, 19 Jul 2024 15:46:32 -0400 Subject: [PATCH 2/2] use minversion --- gwcs/tests/test_wcs.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/gwcs/tests/test_wcs.py b/gwcs/tests/test_wcs.py index f78c0ed8..f1f4efee 100644 --- a/gwcs/tests/test_wcs.py +++ b/gwcs/tests/test_wcs.py @@ -1,5 +1,4 @@ # Licensed under a 3-clause BSD style license - see LICENSE.rst -import importlib.metadata import warnings import os.path @@ -15,6 +14,7 @@ from astropy import wcs as astwcs from astropy.wcs import wcsapi from astropy.time import Time +from astropy.utils.introspection import minversion import asdf from .. import wcs @@ -53,7 +53,7 @@ def asdf_open_memory_mapping_kwarg(memmap: bool) -> dict: - if tuple(int(part) for part in importlib.metadata.version("asdf").split(".")) >= (3, 1, 0): + if minversion("asdf", "3.1.0"): return {"memmap": memmap} else : return {"copy_arrays": not memmap}