CGAL的三维曲面网格生成

news2025/3/1 4:13:15

 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.coloradmin.cn/o/1278107.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

如何获取唐诗三百首中的名句列表接口

唐诗三百首&#xff0c;是中国文学中最为经典的诗歌选集之一&#xff0c;其中涵盖了大量美丽、深刻的诗句&#xff0c;被广泛传诵。有不少文化爱好者希望能够获取这些名句列表&#xff0c;以便深入理解唐诗的内涵和精华。那么&#xff0c;如何获取唐诗三百首中的名句列表呢&…

虚假IP地址攻击的溯源方法

随着网络技术的迅速发展&#xff0c;网络攻击行为也日益猖獗。其中&#xff0c;虚假IP地址攻击是一种较为常见的网络攻击方式&#xff0c;它利用虚假的IP地址&#xff0c;通过互联网对目标进行攻击和入侵。这种攻击方式不仅难以追踪&#xff0c;而且往往会给企业和个人带来巨大…

代码随想录day3 203.移除列表元素 707.设计链表 206.反转链表

数组是在内存中是连续分布的&#xff0c;但是链表在内存中可不是连续分布的。 双链表 单链表中的指针域只能指向节点的下一个节点。 双链表&#xff1a;每一个节点有两个指针域&#xff0c;一个指向下一个节点&#xff0c;一个指向上一个节点。 双链表 既可以向前查询也可以…

k8s ingress 无法找到端点

文章目录 ingress rule无法找到端点这个注解是什么意思呢&#xff1f;为何不生效呢&#xff1f;端点无法更新&#xff1f;如何确认ingressclass呢&#xff1f;修复端点无法发现的问题多个ingress controller 架构 ingress rule无法找到端点 在vnnox-cn集群创建ingress&#xf…

C++学习之路(十六)C++ 用Qt5实现一个工具箱(为屏幕颜色提取功能增加一个点击复制的功能)- 示例代码拆分讲解

上篇文章&#xff0c;我们用 Qt5 实现了在小工具箱中添加了《颜色代码转换和屏幕颜色提取功能》功能。今天我们把屏幕颜色提取的功能再扩展一下&#xff0c;让它可以点击复制吧。下面我们就来看看如何来规划开发这样的小功能并且添加到我们的工具箱中吧。 老规矩&#xff0c;先…

前端面试JS— JS数据类型及相关内容

目录 JS数据类型 基本数据类型&#xff1a; 引用数据类型&#xff1a; 两种数据存储方式&#xff1a; 两种数据类型的区别&#xff1a; 数据类型的检测方式 null和undefined区别 JS数据类型 基本数据类型&#xff1a; Number&#xff0c;String&#xff0c;Boolean&#xff0c;…

使用Pytorch从零开始实现BERT

生成式建模知识回顾: [1] 生成式建模概述 [2] Transformer I&#xff0c;Transformer II [3] 变分自编码器 [4] 生成对抗网络&#xff0c;高级生成对抗网络 I&#xff0c;高级生成对抗网络 II [5] 自回归模型 [6] 归一化流模型 [7] 基于能量的模型 [8] 扩散模型 I, 扩散模型 II…

【并发编程】volatile实现原理解析

&#x1f4eb;作者简介&#xff1a;小明Java问道之路&#xff0c;2022年度博客之星全国TOP3&#xff0c;专注于后端、中间件、计算机底层、架构设计演进与稳定性建设优化&#xff0c;文章内容兼具广度、深度、大厂技术方案&#xff0c;对待技术喜欢推理加验证&#xff0c;就职于…

最小生成树算法

文章目录 最小生成树概述 P r i m Prim Prim 算法 - 稠密图 - O ( n 2 ) O(n^2) O(n2)思路概述时间复杂度分析AcWing 858. Prim算法求最小生成树CODE K r u s k a l Kruskal Kruskal 算法 - 稀疏图 - O ( m l o g m ) O(mlogm) O(mlogm)思路解析时间复杂度分析AcWing 859. Kr…

Java数据结构之《哈希查找》题目

一、前言&#xff1a; 这是怀化学院的&#xff1a;Java数据结构中的一道难度中等的一道编程题(此方法为博主自己研究&#xff0c;问题基本解决&#xff0c;若有bug欢迎下方评论提出意见&#xff0c;我会第一时间改进代码&#xff0c;谢谢&#xff01;) 后面其他编程题只要我写完…

7.C转python

1.对字典的各种操作都是对键来进行的 2.关于字典的遍历操作 例: 还可以这样遍历 所以生成了一个固定模版来遍历字典: 例: 那两个名字可以换 例: 3.合法key的类型: 要求可哈希 在python中,专门提供了一个hash()函数来计算哈希值 例: 有的类型是不能计算哈希的,如:列表,字…

YOLOv8界面-目标检测+语义分割+追踪+姿态识别(姿态估计)+界面DeepSort/ByteTrack-PyQt-GUI

YOLOv8-DeepSort/ByteTrack-PyQt-GUI&#xff1a;全面解决方案&#xff0c;涵盖目标检测、跟踪和人体姿态估计 YOLOv8-DeepSort/ByteTrack-PyQt-GUI是一个多功能图形用户界面&#xff0c;旨在充分发挥YOLOv8在目标检测/跟踪和人体姿态估计/跟踪方面的能力&#xff0c;与图像、…

腾讯云云服务器功能与优势

腾讯云云服务器&#xff08;Cloud Virtual Machine&#xff0c;CVM&#xff09;是腾讯云提供的可扩展的计算服务。使用云服务器 CVM 避免了使用传统服务器时需要预估资源用量及前期投入的问题&#xff0c;帮助您在短时间内快速启动任意数量的云服务器并及时部署应用程序。 云服…

在 AlmaLinux9 上安装Oracle Database 23c

在 AlmaLinux9 上安装Oracle Database 23c 0. 下载 Oracle Database 23c 安装文件1. 安装 Oracle Database 23c3. 连接 Oracle Database 23c4. &#xff08;谨慎&#xff09;卸载 Oracle Database 23c 0. 下载 Oracle Database 23c 安装文件 版权问题&#xff0c;下载地址请等待…

ASP.NET版本WOL服务的使用

本文以WOL为例&#xff0c;演示如何通过 GPT-4 让其为 WebAPI 项目设计一个网页。其中介绍了如何让GPT4生成相关功能&#xff0c;添加动画效果&#xff0c;接口鉴权等。 1. 背景 前面我们已经完成了一个WOL服务的开发&#xff0c;并将其迁移改造为了 ASP.NET 服务并完成了部署…

电脑提示mfc100u.dll缺失如何解决?分享有效的5个解决方法

由于各种原因&#xff0c;电脑可能会出现一些问题&#xff0c;其中之一就是电脑提示mfc100u.dll的错误。这个问题可能会导致电脑无法正常运行某些程序或功能。为了解决这个问题&#xff0c;我将分享验证有效的五个修复方法&#xff0c;帮助大家恢复电脑的正常运行。 首先&#…

【spring(六)】WebSocket网络传输协议

&#x1f308;键盘敲烂&#xff0c;年薪30万&#x1f308; 目录 核心概要&#xff1a; 概念介绍&#xff1a; 对比HTTP协议&#xff1a;⭐ WebSocket入门案例&#xff1a;⭐ 核心概要&#xff1a; websocket对比http 概念介绍&#xff1a; WebSocket是Web服务器的一个组件…

一、服务器准备

本案例使用VMware Workstation Pro虚拟机创建虚拟服务器来搭建Linux服务器集群&#xff0c;所用软件及版本如下&#xff1a; Centos7.7-64bit 1、三台虚拟机创建 第一种方式&#xff1a;通过iso镜像文件来进行安装(不推荐) 第二种方式&#xff1a;直接复制安装好的虚拟机文…

CAP BASE理论

CAP & BASE理论详解 CAP 理论 简介 CAP 也就是 Consistency&#xff08;一致性&#xff09;、Availability&#xff08;可用性&#xff09;、Partition Tolerance&#xff08;分区容错性&#xff09; 这三个单词首字母组合。 CAP 理论的提出者布鲁尔在提出 CAP 猜想的时…

LZW的编码和解码

不同于哈弗曼编码针对于每个元素编码&#xff0c;LZW主要针对字符串的编码优化&#xff0c;也就是把出现频率高的字符串压缩成一个字符表示&#xff0c;这也是大名鼎鼎的GIF采用的压缩格式。下面我将从三个角度谈谈我的一些理解&#xff0c;文章主要参考了这位大佬&#xff1a;…