diff --git a/CHANGES.md b/CHANGES.md index 7ac82ef..7527a5f 100644 --- a/CHANGES.md +++ b/CHANGES.md @@ -20,6 +20,7 @@ - FIX: Use `np.tan` in `rasters.slope` - FIX: Allow str as paths in `ci.assert_files_equal` - FIX: Better alignement between `rasters.read` function and `rasters.any_raster_to_xr_ds` decorator +- FIX: Fix `rasters.sieve` function with `xr.apply_ufunc` - OPTIM: Compute the spatial index by default in `vectors.read` (set `vectors.read(..., compute_sindex=False)` if you don't want to compute them) - CI: Rename CI folder and remove unnecessary intermediate folder diff --git a/ci/test_rasters.py b/ci/test_rasters.py index 99cb7ac..74680a3 100644 --- a/ci/test_rasters.py +++ b/ci/test_rasters.py @@ -314,7 +314,7 @@ def test_crop(tmp_path, xda, xds, xda_dask, mask): @s3_env @dask_env -def test_sieve(tmp_path, xda, xds, xda_dask): +def test_sieve(tmp_path, raster_path, xda, xds, xda_dask): """Test sieve function""" # DataArray xda_sieved = os.path.join(tmp_path, "test_sieved_xda.tif") @@ -348,6 +348,10 @@ def test_sieve(tmp_path, xda, xds, xda_dask): ci.assert_raster_equal(xda_sieved, raster_sieved_path) ci.assert_raster_equal(xds_sieved, raster_sieved_path) + # From path + sieve_xda_path = rasters.sieve(raster_path, sieve_thresh=20, connectivity=4) + np.testing.assert_array_equal(sieve_xda, sieve_xda_path) + @s3_env @dask_env diff --git a/sertit/rasters.py b/sertit/rasters.py index c2a71e8..52ca67c 100644 --- a/sertit/rasters.py +++ b/sertit/rasters.py @@ -1334,14 +1334,15 @@ def sieve( assert connectivity in [4, 8] - # Use this trick to make the sieve work - mask = np.where(np.isnan(xds.data), 0, 1).astype(np.uint8) - data = xds.data.astype(np.uint8) + mask = xr.where(np.isnan(xds), 0, 1).astype(np.uint8).data + data = xds.astype(np.uint8).data # Sieve try: sieved_arr = xr.apply_ufunc( - features.sieve, data, sieve_thresh, connectivity, mask + features.sieve, + data, + kwargs={"size": sieve_thresh, "connectivity": connectivity, "mask": mask}, ) except ValueError: sieved_arr = features.sieve(