无法使用 Python 中的 scipy 在凹多边形内部生成正确的三角形网格
Fail to generate correct triangle mesh inside of a concaved polygon using scipy in Python
我在工作中遇到一个任务,我需要使用 Python 在几个不同的多边形内部创建三角形网格。尽管多边形是凸包的分段,但每个分段本身都是凹形的。当我尝试使用 scipy.spatial.Delaunay() 时,该算法似乎假定多边形是凸的,并最终在凹包区域之外生成三角形。代码和结果图如下。
for i in range(len(mp)):
dtri = np.array(mp[i])
plt.scatter(dtri[:,0],dtri[:,1])
plt.plot(np.array(fdc_seg[i])[:,0],np.array(fdc_seg[i])[:,1])
tri = Delaunay(dtri,qhull_options="QJ")
triang = mtri.Triangulation(dtri[:, 0],dtri[:, 1],triangles=tri.simplices)
plt.triplot(dtri[:, 0], dtri[:, 1], tri.simplices,lw=0.5, color='red')
plt.show()
polygon shapes
resulted triangle mesh
我在工作中遇到一个任务,我需要使用 Python 在几个不同的多边形内部创建三角形网格。尽管多边形是凸包的分段,但每个分段本身都是凹形的。当我尝试使用 scipy.spatial.Delaunay() 时,该算法似乎假定多边形是凸的,并最终在凹包区域之外生成三角形。代码和结果图如下。
for i in range(len(mp)):
dtri = np.array(mp[i])
plt.scatter(dtri[:,0],dtri[:,1])
plt.plot(np.array(fdc_seg[i])[:,0],np.array(fdc_seg[i])[:,1])
tri = Delaunay(dtri,qhull_options="QJ")
triang = mtri.Triangulation(dtri[:, 0],dtri[:, 1],triangles=tri.simplices)
plt.triplot(dtri[:, 0], dtri[:, 1], tri.simplices,lw=0.5, color='red')
plt.show()
polygon shapes resulted triangle mesh