-
Notifications
You must be signed in to change notification settings - Fork 8
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
/bounds of objects that cross the Antimeridian #77
Comments
😭 there are 2 issues here:
To fix this we can do something like: def get_bounds(geom: Dict) -> Tuple[float, float, float, float]:
"""Get Bounds from GeoJSON geometry and handle multi polygon crossing the antimeridian line.
ref: https://github.com/cogeotiff/rio-tiler-pds/issues/77
"""
if geom["type"] == "MultiPolygon":
bounds = [
featureBounds({"type": "Polygon", "coordinates": poly})
for poly in geom["coordinates"]
]
minx, miny, maxx, maxy = zip(*bounds)
return [max(minx), min(miny), min(maxx), max(maxy)]
return featureBounds(geom) Which will return
|
Seems like no one has taken any action on your rasterio bug? |
Sadly even if we fix the |
@jonaraphael I just publish a new version with a fix for #78 and the multi-polygon bug BUT this won't fix the underlying issue in rasterio: rasterio/rasterio#2892) |
Thank you for the progress! |
is there anyway you can provide the file in rasterio 2892 without it being on user-pays S3? I'd like to explore this. |
Any progress? |
I think it should be solved now from rio_tiler_pds.sentinel.aws import S1L1CReader
with rasterio.Env(AWS_REQUEST_PAYER="requester"):
with S1L1CReader("S1A_IW_GRDH_1SDV_20230726T183302_20230726T183327_049598_05F6CA_31E7") as s1:
print(s1.bounds)
(175.38292995222957, 61.06949078480844, -179.34123633603335, 62.88226850489882) |
Typically objects are compact single polygons that return reasonable values
[minx, miny, maxx, maxy]
when you get their bounding box.Case of interest:
When an object crosses the antimeridian (i.e. ±180º longitude), the typical behavior is splitting it into a multipolygon with disconnected elements on opposite sides of the map.
Current behavior:
The current implementation of the
/bounds
endpoint does not treat this correctly... It returns a degenerate bbox that looks like[-180, miny, 180, maxy]
, spanning the whole globePreferred behavior:
Instead, according to the GeoJSON spec: https://datatracker.ietf.org/doc/html/rfc7946#section-5.2 , the bbox should have the "wrong" order for the longitude coordinates (i.e.
minx > maxx
).Note that it is not simply enough to return
[180, miny, -180, maxy]
. The endpoint should actually find the leftmost bound of the rightmost polygon asminx
, and the rightmost point of the leftmost polygon asmaxx
.A frontend application may then choose to handle this case as best they see fit, for instance see: https://github.com/developmentseed/rio-viz/blob/main/rio_viz/templates/index.html#L1202-L1210
Open question:
I'm not sure how this behavior should be defined in more complex situations, where the object is not convex. For instance, a U-shaped polygon that crosses the antimeridian could result in multipolygon with 3 components.
Example:
/bounds?sceneid=S1A_IW_GRDH_1SDV_20230726T183302_20230726T183327_049598_05F6CA_31E7
returns
[-180.0, 61.06949078480844, 180.0, 62.88226850489882]
because it's productInfo.json looks similar to this:
The text was updated successfully, but these errors were encountered: