【发布时间】:2019-02-26 16:53:44
【问题描述】:
我有一个用空间中 (x,y) 点列表定义的几何。我想用这些数据创建一个三角形网格,所以我为此尝试了Triangulation function in matplotlib。但是,由于我的几何图形有一些曲线,因此该算法会在我的零件边缘之间生成不需要的三角形:
红色曲线是我的几何图形的边缘。
有什么办法可以解决这个问题吗?可能三角函数不是我需要的,在这种情况下,你有什么建议吗?
以下代码来自this example。在示例中,他们通过显式命名三个点而不是我想通过调用函数使用的 Delaunay 三角剖分来定义三角形:triang = tri.Triangulation(x, y),这将使我得到与原始图片相同的行为。
import matplotlib.pyplot as plt
import matplotlib.tri as tri
import numpy as np
xy = np.asarray([
[-0.101, 0.872], [-0.080, 0.883], [-0.069, 0.888], [-0.054, 0.890],
[-0.045, 0.897], [-0.057, 0.895], [-0.073, 0.900], [-0.087, 0.898],
[-0.090, 0.904], [-0.069, 0.907], [-0.069, 0.921], [-0.080, 0.919],
[-0.073, 0.928], [-0.052, 0.930], [-0.048, 0.942], [-0.062, 0.949],
[-0.054, 0.958], [-0.069, 0.954], [-0.087, 0.952], [-0.087, 0.959],
[-0.080, 0.966], [-0.085, 0.973], [-0.087, 0.965], [-0.097, 0.965],
[-0.097, 0.975], [-0.092, 0.984], [-0.101, 0.980], [-0.108, 0.980],
[-0.104, 0.987], [-0.102, 0.993], [-0.115, 1.001], [-0.099, 0.996],
[-0.101, 1.007], [-0.090, 1.010], [-0.087, 1.021], [-0.069, 1.021],
[-0.052, 1.022], [-0.052, 1.017], [-0.069, 1.010], [-0.064, 1.005],
[-0.048, 1.005], [-0.031, 1.005], [-0.031, 0.996], [-0.040, 0.987],
[-0.045, 0.980], [-0.052, 0.975], [-0.040, 0.973], [-0.026, 0.968],
[-0.020, 0.954], [-0.006, 0.947], [ 0.003, 0.935], [ 0.006, 0.926],
[ 0.005, 0.921], [ 0.022, 0.923], [ 0.033, 0.912], [ 0.029, 0.905],
[ 0.017, 0.900], [ 0.012, 0.895], [ 0.027, 0.893], [ 0.019, 0.886],
[ 0.001, 0.883], [-0.012, 0.884], [-0.029, 0.883], [-0.038, 0.879],
[-0.057, 0.881], [-0.062, 0.876], [-0.078, 0.876], [-0.087, 0.872],
[-0.030, 0.907], [-0.007, 0.905], [-0.057, 0.916], [-0.025, 0.933],
[-0.077, 0.990], [-0.059, 0.993]])
x = np.degrees(xy[:, 0])
y = np.degrees(xy[:, 1])
triang = tri.Triangulation(x, y)
fig1, ax1 = plt.subplots()
ax1.set_aspect('equal')
ax1.triplot(triang, 'bo-', lw=1)
【问题讨论】:
-
你能贴出你用来制作图片的代码吗?
-
您的点之间似乎有一个最大距离。您可以执行三角剖分并删除其中一个边长大于最大距离的所有三角形。然后用
triplot绘制这个三角剖分。 -
@ThomasKühn 我无法共享我的几何图形,但我可以使用 matplotlib 文档中提供的示例重现该行为。我已编辑我的问题以包含此代码。
-
@ImportanceOfBeingErnest 这对我来说似乎是一个很好的解决方案,但我不知道如何询问特定边缘的长度。你能指导我吗?
-
triag应该有一个属性edges,它将是边缘点的索引,因此允许重建可以再次提供给Triangulation的三角形。现在我只能保证今天晚些时候再仔细看看。
标签: python matplotlib mesh