Skip to content
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

SphericalPolygon.intersection sometimes returns the complement of the intersection #278

Open
Hyfro-Cyrup opened this issue May 29, 2024 · 1 comment

Comments

@Hyfro-Cyrup
Copy link

Hyfro-Cyrup commented May 29, 2024

I have noticed that in some cases, calculating the intersection of two simple polygons can result in their complement. I have not delved deeply into the graph module to find out why this happens or produce other counterexamples, but here is a very simple one:

from spherical_geometry.polygon import SphericalPolygon

p1 = SphericalPolygon.from_cone(90, 0, 100)
p2 = SphericalPolygon.from_cone(270, 0, 100)

print(p1.contains_lonlat(0, 0)) # true
print(p2.contains_lonlat(0, 0)) # true
print(p1.intersection(p2).contains_lonlat(0, 0)) # erroneously false

I defined two caps on either side of the sphere whose intersection should be a thin strip around the prime meridian, or at very least empty if I've defined my polygons wrong.

Not sure why this is happening. I'll try and read through the graph module when I have time unless someone has an idea first. This may be related to #125; they mentioned something similar happening, but the consensus there seemed to be about self-intersection.

version 1.3.1

@Hyfro-Cyrup
Copy link
Author

I believe I have narrowed the issue down to this part of the intersection code:

    poly = self._trace()
    # If multiple polygons, the inside point can only be in one
    if len(poly._polygons) == 1 and not self._contains_inside_point(poly):
        poly = poly.invert_polygon()

The polygon created from the trace doesn't have the right interior, so (I believe) it tries to check for that and correct it using invert_polygon. The issue gets created when invert_polygon does not invert the polygon because of an issue with _get_new_outside: it assumes that points antipodal to the polygon's defining points lie outside the polygon. In my example with a circle of radius >=90, this is clearly false.

_get_new_inside appears to have a similar issue, in that it doesn't take into account which side of the polygon is actually inside, though I don't think that's affecting the intersection bug. Here's a snippet that shows both issues

from spherical_geometry.polygon import SphericalPolygon

p1 = SphericalPolygon.from_cone(90, 0, 100)

print(p1.contains_point(p1.polygons[0]._find_new_inside())) # erroneously false
print(p1.contains_point(p1.polygons[0]._find_new_outside())) # erroneously true

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant