From 03cb853d084724cd1934095ba3cc84e996b2d81d Mon Sep 17 00:00:00 2001 From: Vincent Sarago Date: Tue, 29 Oct 2024 21:49:18 +0100 Subject: [PATCH] Patch/2d xarray point (#761) * fix point method for 2D dataarray * add more tests --- rio_tiler/io/xarray.py | 6 +++++- tests/test_io_xarray.py | 34 +++++++++++++++++++++++++++++++--- 2 files changed, 36 insertions(+), 4 deletions(-) diff --git a/rio_tiler/io/xarray.py b/rio_tiler/io/xarray.py index 6d7cc346..fa843463 100644 --- a/rio_tiler/io/xarray.py +++ b/rio_tiler/io/xarray.py @@ -473,7 +473,11 @@ def point( y, x = rowcol(ds.rio.transform(), ds_lon, ds_lat) - arr = ds[:, int(y[0]), int(x[0])].to_masked_array() + if ds.ndim == 2: + arr = numpy.expand_dims(ds[int(y[0]), int(x[0])].to_masked_array(), axis=0) + else: + arr = ds[:, int(y[0]), int(x[0])].to_masked_array() + arr.mask |= arr.data == ds.rio.nodata return PointData( diff --git a/tests/test_io_xarray.py b/tests/test_io_xarray.py index d05eaca3..b7652f19 100644 --- a/tests/test_io_xarray.py +++ b/tests/test_io_xarray.py @@ -41,7 +41,6 @@ def test_xarray_reader(): assert info.count == 1 assert info.attrs - with XarrayReader(data) as dst: stats = dst.statistics() assert stats["2022-01-01T00:00:00.000000000"] assert stats["2022-01-01T00:00:00.000000000"].min == 0.0 @@ -221,7 +220,6 @@ def test_xarray_reader_external_nodata(): assert info.width == 360 assert info.count == 1 - with XarrayReader(data) as dst: # TILE img = dst.tile(0, 0, 1) assert img.mask.all() @@ -514,7 +512,6 @@ def test_xarray_reader_no_dims(): assert info.count == 1 assert info.attrs - with XarrayReader(data) as dst: stats = dst.statistics() assert stats["value"] assert stats["value"].min == 0.0 @@ -533,6 +530,17 @@ def test_xarray_reader_no_dims(): assert img.band_names == ["value"] assert img.dataset_statistics == ((arr.min(), arr.max()),) + pt = dst.point(0, 0) + assert pt.count == 1 + assert pt.band_names == ["value"] + assert pt.coordinates + xys = [[0, 2.499], [0, 2.501], [-4.999, 0], [-5.001, 0], [-170, 80]] + for xy in xys: + x = xy[0] + y = xy[1] + pt = dst.point(x, y) + assert pt.data[0] == data.sel(x=x, y=y, method="nearest") + def test_xarray_reader_Y_axis(): """test XarrayReader with 2D dataset.""" @@ -568,6 +576,16 @@ def test_xarray_reader_Y_axis(): img = dst.tile(1, 1, 2) assert img.array[0, 0, 0] > img.array[0, -1, -1] + pt = dst.point(0, 0) + assert pt.count == 1 + assert pt.coordinates + xys = [[0, 2.499], [0, 2.501], [-4.999, 0], [-5.001, 0], [-170, 80]] + for xy in xys: + x = xy[0] + y = xy[1] + pt = dst.point(x, y) + assert pt.data[0] == data.sel(x=x, y=y, method="nearest") + # Create a DataArray where the y coordinates are in decreasing order # (this is typical for raster data) # This array will have a negative y resolution in the affine transform @@ -599,3 +617,13 @@ def test_xarray_reader_Y_axis(): img = dst.tile(1, 1, 2) assert img.array[0, 0, 0] < img.array[0, -1, -1] + + pt = dst.point(0, 0) + assert pt.count == 1 + assert pt.coordinates + xys = [[0, 2.499], [0, 2.501], [-4.999, 0], [-5.001, 0], [-170, 80]] + for xy in xys: + x = xy[0] + y = xy[1] + pt = dst.point(x, y) + assert pt.data[0] == data.sel(x=x, y=y, method="nearest")