我在工作中遇到了一个任务,我需要用Python在几个不同的多边形内部创建三角形网格。虽然这些多边形是一个凸壳的分割,但每个分割本身是凹形的,我试着用scipy.spatial.Delaunay()来创建三角形网格。当我尝试使用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()