基于MATLAB 实现二维delaunay 三角剖分

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

基于MATLAB 实现二维delaunay 三角剖分

刘锋涛凡友华

(哈尔滨工业大学深圳研究生院深圳518055)

【摘要】在已知凸多边形的顶点坐标的前提情况下,利用MATLAB 中的meshgrid 函数产生多边形附近矩形区域内的网格点的坐标,然后再利用inpolygon 函数判断哪些点位于多边形内和哪些点位于多边形的边界上。在此基础上利用delaunay 函数来完成delaunay 三角剖分。

【关键词】delaunay 三角剖分;MATLAB

网格划分是有限元分析前处理中的关键步骤,网格划分的密度以及质量对有限元计算的精度、效率以及收敛性有着重要的影响作用。自20世纪70年代开始,关于有限元网格生成方法的研究已经取得了许多重要成果,提出许多有效的算法。Ho-Le 对网格生成方法进行了系统的分类[1]。许多学者也对网格生成的方法进行了综述,如我国的学者胡恩球等[2]、关振群等[3]。

Delaunay 三角剖分(简称DT)是目前最流行的通用的全自动网格生成方法之一。DT 有两个重要特性:最大-最小角特性和空外接圆特性。DT 的最大-最小角特性使它在二维情况下自动地避免了生成小内角的长薄单元。因此特别适用于有限元网格生成。大体上可将DT 算法分为三大类:分治算法,逐点插入法和三角网生长法。经典DT 技术已经相当成熟,近年来的研究重点是约束DT 的边界恢复算法,以及如何克服算法退化现象所产生的薄元(sliver element)问题[3]。

然而,实现DT 有限元网格生成,对于非计算机图形学专业的工程师来说还是很复杂的。在处理一些对有限元网格划分质量不过的问题时,如极限分析的有限元方法,可以采用一些更为简单的方法来实现。在Matlab 计算软件中,已有一个成熟的函数delaunay 可以实现对一系列点的DT 划分。因此,本文基于Matlab 的delaunay 等一些函数来完成一个凸多边形的DT 网格划分。

1MATLAB 中的函数

1.1delaunay 函数

delaunay 函数可以按照DT 网格划分的要求将一个点集中的点划归某一个有限网格所有。它在Matlab 中的用法如下:

=delaunay(,) or,

=delaunay(,,)

TRI x y TRI x y options 其输入为点集中所有点的横、纵坐标向量x 和y ,返回值为一个的矩阵,矩阵中每一3m ×行表示DT 网格中一个三角形网格的三个顶点。

1.2meshgird 函数

为了在任意凸多边形内产生一个点集,可以利用Matlab 中的meshgrid 命令。其用法如下:

[,] = meshgrid(,)

X Y x y

其输入为矩形的x、y方向上的范围,输出为两个向量,分别表示x和y方向上满足一定间距的点的坐标。

1.3inpolygon函数

inpolygon函数的作用是判断一个点是否存在于一个多边形内。它的用法是,

IN ON X Y xv yv

[] = inpolygon(,,,)

其输入值X和Y分别表示点集中每个点的x和y坐标值,而xv和yv则分别表示多边形定点的x和y坐标值。若点集中某一点在多边形内则其返回值IN为1,若不在则IN为0,若某一点在多边形的边界上则ON为1,若不在边界上则ON为0。

1.4基于MATLAB的简单DT方法

在MATLAB中,基于delaunay函数、meshgrid函数和inpolygon函数完成DT网格划分的步骤是:

(1)定义一个多边形,并求出多边形顶点最大的x、y坐标值。

(2)以最大的x、y坐标值作为x和y方向上的长度构造一个矩形。

(3)利用meshgrid函数在构造的矩形区域内构造出一个点集,其密度可以根据需要进行加密。

(4)利用inpolygon函数判断点和多边形的位置关系,求出位于多边形内和边界上的点。(5)再利用delaunay函数将在多边形内和边界上的点进行三角形划分,之后,可以利用trimesh 函数将图形绘制出,并可以得出三角形的顶点坐标和编号。

2一个简单的例子

任意定义一个凸多边形,如图1。按照2.4节中的步骤,对其进行网格划分,划分结果见图2。部分主要的程序见附录。

图1定义的多边形图2delaunay网格划分结果从图2中,可以看出凸多边形内部的三角形划分结果比较理想,但是边界处出现了很薄的三角形单元,并且内部的网格划分的密度一致。然而,对于一些对网格质量要求不高的具体问题还是可以忍受的。

3讨论

此种方法主要是基于Matlab中现有的函数命令来实现DT网格划分的,因此对于那些不熟悉计算机图形学基础知识的工程技术人员而言,很容易掌握并自己编程实现。这也是使

用该方法的主要目的。然而,在此方法中还存在着几个问题:

(1)此种方法只能用于凸多边形的DT划分;

(2)网格划分结果不能实现在同一个区域内不同网格密度的划分;

(3)边界处网格划分的结果不理想,有很薄的三角形单元出现。

若对以上三个要求的不高,则此种方法可以发挥其简单易用的优势,使DT网格划分技术更加容易掌握。

参考文献

[1]K.Ho-Le.Finite element mesh generation method:A review and puter Aided Design,1988,20(1):27~38

[2]胡恩球,张新访,向文,周济.有限元网格生成方法发展综述.计算机辅助设计与图形学学报.1997, 9(4):378~383

[3]关振群,宋超,顾元宪,隋晓峰.有限元网格生成方法研究的新进展.计算机辅助设计与图形学学报. 2003,15(1):1~14

相关文档
最新文档