基于Centroidal Voronoi Tessellation (CVT)算法的点云三角网格化方法

在之前的博客中,老甘已经跟大家提到过Centroidal Voronoi Tessellation(CVT)算法的实现与可视化。

链接:https://blog.csdn.net/aliexken/article/details/106555993

这里我们来介绍一下基于CVT算法的应用,基于点云数据的三角网格化。

1. 网格化

基于CVT算法的一个非常重要的应用就是针对于点云数据的三角网格化[1][2]。基本的步骤就是首先对点云数据进行均匀重采样,得到一个被优化过的点云。基于优化点云,利用与Voronoi图对偶的Delaunay三角化结果,生成一个近似全局同构的三角网格。这个三角网格因为是基于被优化的点云而生成的,因此该三角化的同构性非常好,网格质量比传统方法要高很多。

基于之前的CVT实现,我实现了该功能,对比传统的Poisson曲面重建方法,结果如下:

 

左图为原始的点云数据,取自Bunny的obj文件。中图为利用Poisson算法对点云数据进行重建,生成网格数据。右图为基于CVT算法生成的三角网格。可以看到,右图的三角网格中,三角形的同构性质更好。同构性好的三角网格,在计算曲面特征的时候更便利,如测地线测算等。

2. CVT对网格的优化

那么我们具体来看一下CVT算法在点云三角网格化这件工作中是如何运行的。首先,我们利用CVT算法对一个不规则的点云数据进行同构优化,最终得到一个同构的点云重采样。在每一步的更新迭代后,点云数据就会更加趋向与同构。下图中展示不同的更新阶段,点云数据的三角网格重建结果:

 

从左到右,CVT更新次数对应为:1,5,10,100。可以看到,整个三角网格的质量随着迭代次数的增加而改善。为了更加方便的查看网格质量,这里我做了一个半边结构的可视化,方便读者更加直观的理解面片的质量。其中左图为poisson重建后的结果,右图为CVT优化后的结果。我们可以非常直观的看到,经过CVT优化的面片,其半边结构的规整度更高。

 

3. CVT在实际使用中的注意事项

这里有三点需要注意:

第一, 相关的参考文献中,声称基于CVT算法的网格重建能够利用并行结构而实现加速。对于CVT更新来说,每次更新都需要对上一次定位的点建立搜索结构来提高紧邻查找效率,那么实际上这个并行结构是要在一次迭代后重新整合的,因此按照我目前的理解,还不能建立全程并行的实现方法。所以随着迭代次数与采样点的增加,时间开销必然会显著增加

第二,这里的三角网格是对每一个点与紧邻计算Voronoi图,进而得到其对偶的Delaunay三角化结果。最后的结果是将所有的点的Delaunay三角化组合起来,进而得到一个三角网格数据。这种三角化难免会出现局部丢失面片的情况,因此在实际使用中的时候,需要去修补面片丢失的区域。

第三,在对每一点进行最近邻查找的时候,在曲率变化sharp的地方,可能会发生错误的连接情况(下图中左图为例)。原因是,最近邻是根据欧氏距离来做的,而不是测地线。一个解决的办法是将法线约束引入紧邻查找,以防止相邻点的错误连接(下图中中图为例)。可以看到错误连接的情况有一定的改善,剩余的孔洞可以通过对边界探查并修补来填充。

有兴趣的各位可以利用我提供的Voronoi图代码,或者CGAL库的功能函数实现看看。

参考文献:

[1] Yan et al. Isotropic Remeshing with Fast and Exact Computation of Restricted Voronoi Diagram, 2009.

[2] Bruno et al. Variational Anisotropic Surface Meshing with Voronoi Parallel Linear Enumeration, 2012.

 

  • 4
    点赞
  • 35
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论
### 回答1: 点云数据是一种三维数据表示方法,它由许多离散的点组成,这些点记录了对象表面上的空间位置信息。点云数据广泛应用于三维建模、机器视觉、三维重建等领域。其中,点云三角和补洞是常见的点云处理任务。 点云三角指的是将一组离散的点转换为三角面片,这样可以对点云进行更方便的处理,例如表面重建、形状分析等。点云三角算法有许多种,包括基于Delaunay三角方法、基于Voronoi图的方法等。 点云的补洞指的是将点云中的空洞或缺失部分进行补全。点云补洞可以使用多种方法,包括基于模型的方法、基于形态学的方法、基于切向分析的方法等。其中,基于模型的方法是指使用已知的三维模型来填补空洞或缺失部分;基于形态学的方法是指使用图像处理中的形态学方法来填补空洞或缺失部分;而基于切向分析的方法则是指根据点云表面的法向量来推测空洞或缺失部分的形状,并进行补全。 点云三角和补洞是点云处理中的重要任务,它们能够使点云数据更加完整和便于处理,同时也为点云在各种应用领域中发挥更大的作用提供了有力的支持。 ### 回答2: 点云是由一系列离散的点构成的三维数据集合,通常是由3D测量设备扫描得到的。点云pcl三角是将点云三角网格表示的技术,主要分为两个步骤:三角测量和三角网格化三角测量就是将点云中的点用三角形连接起来,形成有连通性的三角面片。这一步可以利用点云库pcl中的triangulation类实现,该类中有多种算法可供选择,如Delaunay三角剖分、表面重构和alpha形等。 补洞是指将点云中的缺失部分或者噪声点进行补全,使其满足三角的要求。常见的方法包括插值法、拓扑修复法和贴合法等。其中,插值法是一种基于离散数据的方法,根据离散点之间的关系,补全缺失部分的值。拓扑修复法则是通过维护表面拓扑结构,将缺失部分利用三角网格与其它部分衔接起来。贴合法则是将三角网格粘贴到点云表面上,得出一个闭合的表面。 在实际应用中,三角和补洞技术可以结合使用,对点云进行处理,以得到更加准确的模型。由于点云pcl三角补洞是一个相对较复杂的过程,因此对于不同的应用场景和具体任务,需要根据实际情况选择合适的算法进行处理。 ### 回答3: 点云pcl三角补洞是指在三维点云数据中存在一些缺失点数据,需要进行补洞操作以便于后续处理。该操作常用于深度图像的三维重建、物体识别及自动驾驶等领域。 在点云数据处理中,补洞操作常采用三角方法,即通过给出点云数据中缺失点周边的点集,构建三角网格面的方法进行补洞。具体步骤包括以下几个方面: 首先,需要对点云数据进行清洗,去除野点、重复点及噪声点等无效数据,保留所需的数据。随后,需要进行点云数据的三角,将点云数据分解成许多小的三角面片。接着,通过计算三角面片边和面的长度、角度等信息,构建有向图模型,并使用Dijkstra等算法确定从任意点开始遍历的最短路径。 在确定了点云数据中缺失点周边的点集之后,需要使用三角方法构建以这些点为顶点的三角形。这就需要采用特定的三角算法,如Delaunay三角,将点云数据恢复成可处理的网格数据。最后,通过Further修复算法方法三角网格中的不连续面进行修复,使点云数据中的缺失部分得到完善。 总之,点云pcl三角补洞是一种常用的点云数据处理方法,其过程需要仔细处理各个步骤,以确保构建出合理的三角网格面,恢复出完整的点云数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序猿老甘

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值