我正在使用matplotlib和shapely测试点与多边形的关系。
这里有一个包含百慕大三角形多边形的地图。
Google maps中的点与多边形函数清晰地显示testingPoint和testingPoint2在多边形内,这是正确的结果。
如果我在matplotlib和shapely中测试这两个点,只有point2通过测试。
In [1]: from matplotlib.path import Path
In [2]: p = Path([[25.774252, -80.190262], [18.466465, -66.118292], [32.321384, -64.75737]])
In [3]: p1=[27.254629577800088, -76.728515625]
In [4]: p2=[27.254629577800088, -74.928515625]
In [5]: p.contains_point(p1)
Out[5]: 0
In [6]: p.contains_point(p2)
Out[6]: 1
Shapely 显示的结果与 matplotlib 相同。
In [1]: from shapely.geometry import Polygon, Point
In [2]: poly = Polygon(([25.774252, -80.190262], [18.466465, -66.118292], [32.321384, -64.75737]))
In [3]: p1=Point(27.254629577800088, -76.728515625)
In [4]: p2=Point(27.254629577800088, -74.928515625)
In [5]: poly.contains(p1)
Out[5]: False
In [6]: poly.contains(p2)
Out[6]: True
这里到底发生了什么?Google的算法比这两个更好吗?
谢谢。
matplotlib
来进行转换呢? - Mikael S.