CGAL的三维曲面网格生成

 1、介绍

        此程序包提供了一个函数模板,用于计算三角网格,以近似表面。

        网格化算法要求仅通过一个能够判断给定线段、直线或射线是否与曲面相交,并且如果相交则计算交点的oracle来了解待网格化的表面。这一特性使该软件包具有足够的通用性,可以应用于各种情况。例如,它可以用于网格化隐式曲面,如某些函数的零水平集。它也可以用于医学成像领域,网格化三维图像中的灰度级集曲面。

        网格化算法基于受限的Delaunay三角剖分概念。该算法基本上是在曲面上计算一组采样点,并从这些采样点的三维三角剖分中提取插值曲面网格。与Delaunay细化过程一样,迭代地将点添加到采样中,直到满足曲面网格元素的一些尺寸和形状标准。

        尺寸和形状标准指导细化过程的行为并控制其终止。它们还决定了最终网格中元素的大小和形状。自然地,这些标准可以定制以满足用户需求。曲面网格生成包提供了一组可以通过三个数值进行缩放的标准。此外,用户还可以插入自己的一组细化标准。

        如果用户能够在每个连接的组件上提供一个初始采样点,则对表面的拓扑和组件数量没有限制。如果表面足够光滑,并且尺寸标准足够小,则算法保证输出网格与表面同胚,并且与表面之间的距离很小(豪斯多夫距离甚至弗雷歇距离)。该算法也可用于非光滑表面,但无法保证。

2、用于光滑曲面的曲面网格生成器接口

        网格划分过程是通过调用函数模板来启动的。网格划分函数有两种重载版本,其特征如下: 

template <class SurfaceMeshC2T3,class Surface,class FacetsCriteria,class Tag >
void make_surface_mesh(SurfaceMeshC2T3& c2t3,Surface surface,FacetsCriteria criteria,Tag);
template< class SurfaceMeshC2T3,class SurfaceMeshTraits,class FacetsCriteria,class Tag >
void make_surface_mesh(SurfaceMeshC2T3& c2t3,SurfaceMeshTraits::Surface_3 surface,SurfaceMeshTraits traits,FacetsCriteria criteria,Tag );

         模板参数 SurfaceMeshC2T3 表示用于存储表面网格的数据结构类型。此类型需要是概念 SurfaceMeshComplex_2InTriangulation_3 的模型。此类数据结构具有指向三维三角剖分的指针,并将表面网格编码为此三角剖分中面的子集。类型 SurfaceMeshC2T3 的参数通过引用传递给网格化函数。此参数在过程结束时保存输出网格。

        模板参数 Surface 表示表面类型。该类型必须是概念 Surface_3 的模型。

        表面网格生成器所需的表面知识被封装在一个 traits 类中。实际上,网格生成器仅通过此 traits 类访问要网格化的表面。traits 类需要是概念 SurfaceMesh_Traits_3 的模型。 make_surface_mesh() 的两个重载版本之间的区别可以解释如下

        在 make_surface_mesh() 的第一个重载版本中,表面类型作为模板参数给出,要网格化的表面作为参数传递给网格生成器。在这种情况下,表面网格生成器特征类型由一个名为 Surface_mesh_traits_generator_3 的辅助类从表面类型自动生成。

        在 make_surface_mesh() 的第二个重载版本中,表面网格生成器特征类型由模板参数 SurfaceMeshTraits_3 提供,表面类型从此特征类型获得。表面和特征都作为参数传递给网格生成器。

        当表面类型提供嵌套类型 Surface::Surface_mesher_traits_3 作为 SurfaceMesh Traits_3 的模型,或者提供 traits 生成器 Surface_mesh_traits_generator_3<Surface> 的特化的表面类型时,可以使用第一个重载版本。目前,该库为隐式表面(Implicit_surface_3<Traits, Function>)和灰度图像(Gray_level_image_3<FT, Point>)提供了 Surface_mesh_traits_generator_3<Surface> 的部分特化。

        参数标准处理驱动网格划分过程的大小和形状标准的描述。模板参数FacetsCriteria必须由概念SurfaceMeshFacetsCriteria_3的模型实例化。

        参数Tag是一个标签,其类型会影响网格算法的行为。例如,此参数可用于强制输出网格的流形属性,同时避免网格的过度细化。

        调用 make_surface_mesh(c2t3,surface, criteria, tag) 会启动网格化过程,并使用一组初始点,该组初始点是两个子集的并集:c2t3 指向的初始三角剖分中的顶点集,以及 traits 类的 Construct_initial_points() 函子提供的一组点。该初始点集需要包含要网格化的曲面的每个连通分量上的至少一个点。

3、输入输出

        使用函数 CGAL::output_surface_facets_to_off()可以将表面网格输出为OFF格式。

4、网格生成标准、保证、变化

        输出网格的保证取决于网格标准。首先,如果面角度的下限不大于30度,则证明网格算法终止。此外,输出网格保证与表面同胚,并且如果半径范围处处小于\(\epsilon)倍局部特征尺寸,则网格和表面之间的距离(豪斯多夫距离甚至弗雷歇距离)有保证的范围。这里\(\epsilon)是一个必须小于0.16的常数,局部特征尺寸\(\mathrm{lfs}(x)\)在表面的每个点\(x\)上定义为从\(x\)到中轴的距离。请注意,半径范围不需要是均匀的,尽管在默认标准中是均匀的。

        当然,这样的理论保证只能针对具有有限非零到达值的平滑表面来实现。(表面的到达值是该表面上局部特征尺寸的最小值)。

        曲面任何点上的局部特征尺寸值或曲面上的最小值通常是未知的,尽管有时可以猜测。此外,经常发生的情况是,设置网格标准以满足理论条件会产生过度细化的网格。另一方面,当尺寸标准放宽时,不能保证与输入曲面具有同胚性,并且不能保证输出网格是流形。为了解决这个问题,并给出更灵活的网格算法,函数模板 make_surface_mesh() 有一个标记模板参数,可以稍微改变细化过程的行为。这个功能允许,例如,使用放宽的尺寸标准运行网格算法,与用户期望的网格尺寸更加一致,并且仍然保证输出网格形成流形表面。函数 make_surface_mesh() 具有以下标记类型的专用版本:Manifold_tag:输出网格保证为无边界的流形曲面。Manifold_with_boundary_tag:输出网格保证是流形,但可能有边界。Non_manifold_tag:该算法依赖于给定的标准,并且不保证其他任何东西。

5、输出

        该CGAL组件还提供将重建的曲面网格写入对象文件格式(OFF)[2]并将其转换为FaceGraph(当它是流形时)的功能:output_surface_facets_to_off();output_surface_facets_to_polyhedron();facets_in_complex_2_to_triangle_mesh()。

CGAL 5.6 - 3D Surface Mesh Generation: User Manual

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/238593.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

读书笔记-《数据结构与算法》-摘要1[数据结构]

文章目录 [数据结构]1. String - 字符串2. Linked List - 链表2.1 链表的基本操作2.1.1 反转链表单向链表双向链表 2.1.2 删除链表中的某个节点2.1.3 链表指针的鲁棒性2.1.4 快慢指针 3. Binary Tree - 二叉树3.1 树的遍历3.2 Binary Search Tree - 二叉查找树 4. Queue - 队列…

人工智能-优化算法之学习率调度器

学习率调度器 到目前为止&#xff0c;我们主要关注如何更新权重向量的优化算法&#xff0c;而不是它们的更新速率。 然而&#xff0c;调整学习率通常与实际算法同样重要&#xff0c;有如下几方面需要考虑&#xff1a; 首先&#xff0c;学习率的大小很重要。如果它太大&#xf…

acwing算法基础之动态规划--数位统计DP、状态压缩DP、树形DP和记忆化搜索

目录 1 基础知识2 模板3 工程化 1 基础知识 暂无。。。 2 模板 暂无。。。 3 工程化 题目1&#xff1a;求a~b中数字0、数字1、…、数字9出现的次数。 思路&#xff1a;先计算1~a中每位数字出现的次数&#xff0c;然后计算1~b-1中每位数字出现的次数&#xff0c;两个相减即…

7、单片机与W25Q128(FLASH)的通讯(SPI)实验(STM32F407)

SPI接口简介 SPI 是英语Serial Peripheral interface的缩写&#xff0c;顾名思义就是串行外围设备接口。是Motorola首先在其MC68HCXX系列处理器上定义的。 SPI&#xff0c;是一种高速的&#xff0c;全双工&#xff0c;同步的通信总线&#xff0c;并且在芯片的管脚上只占用四根…

uniapp uni-popup组件在微信小程序中滚动穿透问题

起因 在微信小程序中使用uni-popup组件时&#xff0c;出现滚动穿透&#xff0c;并且uni-popup内部内容不会滚动问题。 解决 滚动穿透 查阅官方文档&#xff0c;发现滚动穿透是由于平台差异性造成的&#xff0c;具体解决可以参照文档禁止滚动穿透 <template><page-…

python 实现链表

链表基础知识 链表是在物理内存中不连续&#xff0c;数据通过链表中的指针来链接到下一个元素。 链表由一系列节点组成&#xff0c;节点在运行时动态生成&#xff0c;节点一般包括两个部分&#xff1a;存储数据的数据域&#xff0c;存储下一个节点的指针域 链表的常用操作&a…

熬夜会秃头——beta冲刺Day4

这个作业属于哪个课程2301-计算机学院-软件工程社区-CSDN社区云这个作业要求在哪里团队作业—beta冲刺事后诸葛亮-CSDN社区这个作业的目标记录beta冲刺Day4团队名称熬夜会秃头团队置顶集合随笔链接熬夜会秃头——Beta冲刺置顶随笔-CSDN社区 一、团队成员会议总结 1、成员工作进…

C语言:写一个函数,输入一个十六进制数,输出相应的十进制数

分析&#xff1a; 当用户运行该程序时&#xff0c;程序会提示用户输入一个十六进制数。用户需要在命令行中输入一个有效的十六进制数&#xff0c;例如&#xff1a;"1A3F"。 接下来&#xff0c;程序调用了名为 xbed 的函数&#xff0c;并将用户输入的十六进制数作…

【翻译】直流电动机的控制

直流电&#xff08;DC&#xff09;电机由于其转矩易于控制&#xff0c;速度控制范围广&#xff0c;已广泛应用于可调速驱动或可变转矩控制中。然而&#xff0c;直流电机有一个主要的缺点&#xff0c;即它们需要机械装置&#xff0c;如换向器和刷子来连续旋转。这些机械部件需要…

《opencv实用探索·六》简单理解图像膨胀

1、图像膨胀原理简单理解 膨胀是形态学最基本的操作&#xff0c;都是针对白色部分&#xff08;高亮部分&#xff09;而言的。膨胀就是使图像中高亮部分扩张&#xff0c;效果图拥有比原图更大的高亮区域。 2、图像膨胀的作用 注意一般情况下图像膨胀和腐蚀是联合使用的。 &…

前端面试高频考点—事件循环Event loop

目录 事件循环 执行步骤 概念讲解 主线程 微任务(micro task) 宏任务(macro task) Event Loop经典例题 这段代码的执行结果是什么&#xff1f; 正确答案&#xff1a; 具体流程&#xff1a; 事件循环 主线程从"任务队列"中读取执行事件&#xff0c;这个过程…

利用 NRF24L01 无线收发模块实现传感器数据的无线传输

NRF24L01 是一款常用的无线收发模块&#xff0c;适用于远程控制和数据传输应用。本文将介绍如何利用 NRF24L01 模块实现传感器数据的无线传输&#xff0c;包括硬件的连接和配置&#xff0c;以及相应的代码示例。 一、引言 NRF24L01 是一款基于 2.4GHz 射频通信的低功耗无线收发…