-
Notifications
You must be signed in to change notification settings - Fork 96
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
Bug where boundary coordinates wrap around 180 degrees when geostationary AreaDefinition extends beyond 180 degrees #530
Comments
There is an old PROJ mailing list thread started by me where I discuss this So the longitudes are in the range -180 to 360 technically? Basically going from ~170 to ~220 to keep the pixel offset always positively increasing. Or wait, who is doing the wrapping here? What are the longitudes produced by the AreaDefinition? What projection are you using for mapping/drawing? |
I don't now if this bug is also relevant to the getting full lat/lon arrays. The reason for the bug is that for the boundary calculation in lons/lats the bounding box is calculated in projection coords (geostationary) and then "reprojected" using pyresample/pyresample/geometry.py Line 2823 in 07382cc
AreaDefinition .
I also got the feeling that the usage of While the pm=180 does not mess up the geometry of the polygon the coordinates are shifted and downstream tasks like mapping/selecting are rather difficult and counterintuitive. I think most of the time the recommendation is to split the polygons at the dateline (https://towardsdatascience.com/around-the-world-in-80-lines-crossing-the-antimeridian-with-python-and-shapely-c87c9b6e1513). I don't know what the best way to go here is. I guess this also depends on the usage of the While a different discussion and maybe special to my usage; but I think it would make sense if |
Some of the work by @ghiggi handles these cases by internally having a Boundary object that contains two shapely polygons for the dateline cases. I don't remember where that implementation lives between future boundary/spherical polygon classes and current classes. I think I'd prefer if the lon/lat coordinate generation for the bounds did a wrap check manually (especially since bounding coordinates should not have very many elements). So if What do you think? |
I am a bit tired right now, but I think the issue here @BENR0 is something else. I guess your Polygon vertices are defined clockwise, while shapely expects to be defined as counterclockwise. Can you try to plot with counterclockwise shapely polygon vertices (with i.e. [, ::-1]) and use the the cartopy Geodetic CRS? |
@djhoese in the future spherical polygon interface I found a way to not need two polygons in the dateline cases :D |
@djhoese I agree. The PROJ flags solution, while working or at least giving the results I wanted, seems a little fishy. A manual check would be better I think. From what I grasp I am not sure if it s possible to get away with a single polygon instead of two if it would be crossing the date line but I am very curious what you've come up with @ghiggi. @ghiggi the counterclockwise solution won't work, at least for the "distorted" shapely polygon display, because the one coordinate that is over the dateline and thus positive is due to the inverse projection using Nevertheless I found out something interesting; the geo plot you see above is made from a geopandas dataframe using hvplot using bokeh which is wrong obviously. I now also did a plot just with cartopy and in that case the polygon looks right. Interestingly this is the case in the clockwise and counterclockwise case even though there is some weird artefact with the background map in the clockwise case. But still cartopy obviously knows how to figure out the dateline crossing. Spatial join also seem to be correct in the clockwise and counterclockwise cases So I guess this is a bug with hvplot/bokeh somehow which mislead me. I don't know if this is still a bug then? I guess it would make sense to change the default to counterclockwise since this is also what shapely expects? |
All pyresample polygon spherical routines expect clockwise-ordered vertices ... and would be an ultra-pain to change. Did you try to use Geoviews for the plots? You would still rely on bokeh but you could specify the cartopy geodetic crs and solve the issue I guess .... |
When the extent of geostationary
AreaDefinitions
extend beyond 180 degrees boundary coordinates wrap around 180 degrees and derivedshapely.Polygons
are wrong (this was discovered using theboundary
method but due to bug #529 I am usingget_geostationary_bounding_box_in_lonlats
here instead).Problem description
In this case the top left corner of the boundary gets wrapped around 180 degrees and therefore the resulting polygon is wrong. It can't be used for geo selecting points and when displayed the polygon get's further simplified because I think polygon lines are not allowed to cross themselves.
The reason for this is that
Proj
by default wraps coordinates during transformation. This can be changed by adding+over
to the proj4 CRS string. InPyresample
WKT CRS is used as should be and as far as I could find out this flag can not be directly set in WKT CRS. Instead if a CRS is initialized with+over
the WKT representation gets aREMARK
section with the proj4 string which seems to be respected when doing transformations withProj
.This leads to the expected output below.
Expected Output
Versions of Python, package at hand and relevant dependencies
Python: 3.10.8
Pyresample: v1.27.1
The text was updated successfully, but these errors were encountered: