Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Hi Joe,
“_linear_interp_frac_coordinates” is correct given that it is a basic bilinear interpolation on a bidimensional array (so it should be agnostic to the GPS coordinates).
I think the issue is rather in “_get_coordinates” which should use by default the “PixelIsArea” mode. Indeed, when looking at the coordinates in the data set, they seems to always follows this convention, that is, the latitudes/longitudes are built as in the code snippet below extracted from xarray.open_rasterio:
Hence, the algorithm finding the pixel from latitude/longitude should correspond to the inverse of this function, that is:
~transform * coordinates - 0.5
The interpolation will still be on the edges but the pixel to interpolate will be the green point instead of the red point:
data:image/s3,"s3://crabby-images/89d87/89d87070ddf7357a62e159bb9fb900633cb24896" alt="image"
data:image/s3,"s3://crabby-images/3156f/3156fa540c28af0a717500052d4f528f7e42a6af" alt="image"
Note that it will also impact the “floor” mode. The convention applied to any Zarr store mocker also needs to be updated to apply the 0.5-pixel offset.