基于逐点插入的Delaunay四面体剖分并行算法研究.docVIP

基于逐点插入的Delaunay四面体剖分并行算法研究.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于逐点插入的Delaunay四面体剖分并行算法研究 Delaunay四而体剖分凭借生成网格的高质量性和良好逼近性,其并 行网格生成技术备受业界关注。以逐点插入思想的Delaunay四面体网格 剖分串行算法为基础,采用“网格生成串行算法+新并行策略”的方式, 提出一种基于数据并行的Delaunay四面体剖分并行算法。同时在 Limix+MPI平台上实现上述并行算法,取得了良好的计算效率。 【关键词】Delaunay三角剖分网格生成并行算法并行策略 1引言 随着大型并行计算机软硬件技术的快速发展,网格剖分并行技术已成 为科学工程计算领域研究的热点之一。Delaunay三角剖分是三维空间数值 模拟阶段最基本的逼近单元和3D复杂对象可视化处理屮最佳离散形式, 剖分得到Delaunay三角网格具冇良好的数学特性与优化特性。 基于逐点插入思想的Delaunay三角剖分,构成的网格唯一,性、网格 质量都较好,并且满足Delaunay三角剖分的空圆准则,具有较高的执行 效率。而基于逐点插入的Delaunay四面体剖分内部的并行,鍋合性是制 约其并行效率的主要瓶颈,例如BW并行算法中插入点的冲突问题导致处 理器之间较高的通信耗时,这是决定BW并行算法高低的主要因素。Yagawa 等提出的自由网格法(free mesh method. FMM),有效的规避了鍋合性的 限制,充分利用网格的局部特性,适合大规模并行计算、负载均衡,不过 局部网格生成的质量是决定剖分优劣的关键因素。地球物理勘探中,野外 地层块实体断层之间耦合性很小(如图1所示地震层块体显示),并且可 以通过野外放炮、检波一系列手段获取各个层面的数据点坐标,针对于此 本文结合逐点插入算法和自由网格方法,提出了一种基于数据并行的 Delaunay四面体剖分并行算法,此算法有效缩短了数据点同时插入时通信 耗时,提高了网格剖分效率。 2逐点插入Delaunay四面体剖分串行算法设计 木文提出的并行算法基于逐点插入算法,在此首先给出基于逐点插入 的四血体剖分串行算法的具体实现过程。 2. 1数据结构 定义三种数掘结构Point〃结构、Tetrahedral结构、 Circumscribed sphere结构,数据结构具体定义如下: 2. 1. 1 点 Point 三维情况下的数掘点川二维数组node[i]存储:记录第i个点的横坐 标、纵坐标、竖坐标。 四面体 Tetrahedral 四面体信息存储在四面体信息矩阵中:tera_info[i],分别存储第i 个四面体四个顶点编号和第i个四面体四个外邻四面体编号。 夕卜接球 Circumscribed sphere 三维Delaunay逐点插入算法在执行的过程中要不断搜索四面体外接 球的信息,需要记录下外接球的圆心坐标与半径,用二维数组存储: tctra_circum[],存放第i个四面体外接球的球心横坐标、纵华标、竖绝 标、四面体外接球半径。 2.2算法流程图 三维逐点插入Delaunay四面体剖分申行算法在木文中用于子块体网 格剖分,具体实现过程如图2所示。 3逐点插入Delaunay四面体剖分并行算法设计 3.1并行算法基本思想 首先对三维数据点限定在一个规则的长方体,然后将大块体分割为多 个子块体,每一个子块体含有上下两层数据点(相邻两个子块共享一层数 据),对每一子块体针对上下两层数据点采用三维逐点插入Delaunay剖分 串行算法进行四面体网格生成。然后合并子块剖分之后得到的局部四面体 网格,得到整体Delaunay四面体网格,如图3所示。 3.2并行算法采用的并行策略 将大块体按层分解为多个子块体,同时每一层数据点存储在一个数据 文件屮,以下给出相关实现。 MPI Comm rank (MPI CO酮 WORLD, rank); MPI Comm size (MPI COMM WORLD, size); //为实现负载均衡,采用交叉数据分解方法 for (int i=rank; i〈layer-1; i=i+proceSize) //layer是大块体被分成子块之后包含的总层数,proceSize启动的 进程的总数量。 { Delaunay_3d:: readdata (fileName[i], node); //fileName□中存储的是多个数据文件名称,一个数据文件储存一层 三维点坐标信息。 Delaunay_3d:: rcad_data (filcName[i+1], node) //读取第i与第i+1两相邻层数据,将数据点信息存储于二维数组 node[][]中 Delaunay_3d:: delaunay (node, node_num_new, i+1); //包含i与i+1层数据的子块体采用前面给出的三维Delauna

文档评论(0)

ggkkppp + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档