上一篇介绍了Marching Cubes算法,Marching Cubes算法是三维重建算法中的经典算法,算法主要思想是检测与等值面相交的体素单元并计算交点的坐标,然后对不同的相交情况利用查找表在体素单元内构建相应的网格拓扑关系。Marching Cubes算法简单,但是存在一些缺陷:1.模型二义性问题;2.模型特征问题。

  对于二义性问题,以2D情形为例,存在一个单元中同一顶点状态而不同的连接方式(如下图所示)。

图:2D中Marching Cubes算法的二义性问题

  那么对于上图中两种连接方式的不同选择,可能会导致在同一张图像上完全不同的结果(如下图所示),二义性在3D中的直接后果是产生“孔洞”。如果在一个单元中,一条对角线的两端点值大于等值面阈值,另一条对角线的两端点值小于等值面阈值,那么通常会发生这种二义性问题。

图:二义性问题的不同结果

  对于特征问题,由于Marching Cubes算法只计算体素单元的交点坐标信息,并根据这些交点连接的三角面片来构建体素单元内的几何模型,这样假如体素单元内存在几何模型的特征信息(棱边、棱角),但是Marching Cubes算法最终构建出的几何模型会缺少这些特征信息(如下图所示)。

图:左上-交点坐标和法向;右上-Marching Cubes算法;左下-Extended Marching Cubes算法;右下-Dual Contouring算法

  Dual Contouring算法[Ju et al. 2002]也是经典的等值面提取算法,相比Marching Cubes算法,Dual Contouring算法利用Hermite数据(交点的位置和法向)进行等值面构建,它克服了Marching Cubes算法所出现的缺陷。具体算法分两步:

  第一步:利用二次误差函数生成顶点坐标

  对于每个与等值面相交的体素单元,通过最小化二次误差函数来生成一个顶点坐标:

其中pi为交点的位置,ni为交点的法向。

  误差函数可以写成矩阵形式:

其中矩阵A的行向量为交点的法向ni,向量b的每个元素为ni·pi

  极值点可以通过求解正则方程得到:

  但是文章指出这种方式会存在数值不稳定,并提出一种解决方法。基于QR矩阵分解计算正交矩阵Q,使得Q与[A b]相乘为如下上三角矩阵形式:

其中A'为3*3的上三角矩阵,b'为长度为3的向量,r为标量。

  那么误差函数可以变化为:

  然后再根据上式计算极值点。

  第二步:生成网格面片

  对于每一条等值面相交的体素边,那么包含该体素边的4个相邻体素单元内必然都存在顶点,将这4个顶点连接生成1个四边形面片。

  

  文章[Schaefer et al. 2002]详细介绍了Dual Contouring算法的实现细节,通过总结该文可以得到Dual Contouring算法过程如下:

  对于每个与等值面相交的体素单元:

  1. 创建1个4*4的零矩阵用于存放QR矩阵分解的结果;

  2. 对于体素单元的每条相交边,计算交点的位置pi和对应的法向ni

  3. 将向量[ ni.x, ni.y, ni.z, dot(pi,ni) ]添加到4*4的零矩阵底部;

  4. 通过QR矩阵分解得到3*3的上三角矩阵A'和向量b';

  5. 求解线性方程组A'TA'x = (A'Tb' - A'Tb'c) , 其中c是体素单元中所有交点的质心位置;

  6. 将计算得到的偏移量x加上质心位置c即为体素单元中的顶点坐标;

  7. 如果计算得到的顶点坐标位于体素单元之外,那么顶点坐标用质心位置c来代替;

  8. 对于每一条相交的体素边,将其周围4个体素单元内的顶点连接生成1个四边形面片。

 

图:左- Marching Cubes算法;右-Dual Contouring算法

 

图:左- Marching Cubes算法;右-Dual Contouring算法

 

图:box与sphere相交模拟

本文为原创,转载请注明出处:http://www.cnblogs.com/shushen。

相关:

水泡动画模拟(Marching Cubes):http://www.cnblogs.com/shushen/p/5542131.html

参考文献:

[1] Tao Ju, Frank Losasso, Scott Schaefer, and Joe Warren. 2002. Dual contouring of hermite data. ACM Trans. Graph. 21, 3 (July 2002), 339-346.

[2] Scott Schaefer and Joe Warren. Dual contouring: The secret sauce. Technical Report 02-408, Department of Computer Science, Rice University, 2002.

[3] http://users.csc.calpoly.edu/~zwood/teaching/csc572/final15/kpidding/index.html

转载于:https://www.cnblogs.com/shushen/p/5607833.html

三维等值面提取算法(Dual Contouring)相关推荐

  1. VTK修炼之道55:图形基本操作进阶_表面重建技术(等值面提取)

    1.等值面提取 等值面(线)提取是一种常用的可视化技术,常应用于医学.地质.气象等领域.例如,在医学图像处理中,由于CT.MRI等图像分辨率越来越高,虽然体绘制技术可以清晰地对数据内部结构进行可视化, ...

  2. 三维目标检测算法原理

    三维目标检测算法原理 输入输出接口 Input: (1)图像视频分辨率(整型int) (2)图像视频格式(RGB,YUV,MP4等) (3)左右两边的车道线位置信息摄像头标定参数(中心位置(x,y) ...

  3. 中线提取算法_综述|线结构光中心提取算法研究发展

    摘 要: 线结构光扫描是三维重建领域的关键技术.光条纹中心提取算法是决定线结构光三维重建精度以及光条纹轮廓定位准确性的重要因素.本文详细阐述了光条纹中心提取算法的理论基础及发展历程,将现有算法分为三类 ...

  4. 传统激光条纹中心提取算法研究现状

    传统激光条纹中心提取算法研究现状 前言 一.边缘法 二.中心法 三.阈值法 四. 细化法 五.极值法 六.灰度重心法 七.方向模板 八.曲线拟合法 九.Steger 前言 光条中心提取是将宽度大于1的 ...

  5. 【必备知识】:线激光条纹中心线提取算法导读

    线激光条纹特性 线激光器是由点激光器和前置透镜组成的.点激光器可以为He-Ne激光器或半导体激光器.相比较He-Ne激光器,半导体激光器因其输出光源具有发散性,更适合用于制作线激光器.需要说明的是,半 ...

  6. android o 结构光流程,结构光光条中心的提取算法.pdf

    结构光光条中心的提取算法 2010年 8月 沈阳航空工业学院学报 A ug. 2010 第 27卷 第 4期 Journa l o f Shenyang Institute of A e ronaut ...

  7. 点云孔洞定位_散乱点云的孔洞识别和边界提取算法研究

    散乱点云的孔洞识别和边界提取算法研究 王春香,孟 宏,张 勇 [摘 要] 针对逆向工程中已有孔洞识别算法执行效率低.孔洞边界点提取不完 整等问题,提出一种新的基于 KD 树和 K 邻域搜索的点云孔洞识 ...

  8. 算法与数据结构java语言描述 英文版_CVPR2020 |室内设计师失业?针对语言描述的自动三维场景设计算法...

    近日,计算机视觉顶会CVPR 2020接收论文结果公布,从6656篇有效投稿中录取了1470篇论文,录取率约为22%.在<Intelligent Home 3D: Automatic 3D-Ho ...

  9. 一种新型鱼眼图像轮廓提取算法

    from: http://www.scimao.com/read/2307651     摘 要:提取鱼眼图像轮廓是利用鱼眼图像的前提.传统提取鱼眼图像轮廓的扫描线逼近法对噪点抑制能力不强,精度差.本 ...

最新文章

  1. 极大似然估计_干货|一文理解极大似然估计
  2. Julia数据统计最全教程,代码图解全都有,昆士兰大学出品,公开免费阅读
  3. MoeCTF 2021Re部分------PE
  4. 排序方法总结C++实现
  5. python 画三角函数_用Python计算三角函数之acos()方法的使用
  6. uva10069-Distinct Subsequences
  7. iOS混合开发库(GICXMLLayout)一、介绍
  8. python 汽车行业数据库_python3+Neo4j+flask,汽车行业知识图谱项目实战
  9. 前端性能优化gzip压缩
  10. 生物信息学最基础知识
  11. F5 LTM1600 HA
  12. heka 配置 一个go语言实现轻量级logstash 干掉ELK
  13. 解决Ubuntu 20.04挂载NTFS分区不能写入(只读权限)的问题
  14. xp 英文版 安装后出现 中文乱码,解决方案。
  15. Matlab 颜色、线型、标记符号和希腊字母表
  16. python是什么意思中文、好学吗-python好学吗
  17. CH2-开发工具DevEco Studio
  18. Python Diango学习之路
  19. Autocad2004与win7和谐共处。
  20. 为何华为的5G专利高居第一名,却还被高通要求缴纳专利费?

热门文章

  1. 入职后发现公司是外包全职_我如何通过全职工作,伴侣和3岁的双胞胎男孩打造产品...
  2. 怎样用matlab打开mw文,C# matlab混合编程 MWArray使用笔记
  3. 逻辑覆盖测试(六)--路径测试
  4. 百练,4103,踩方格
  5. 1032 Sharing
  6. 2018.10.22-dtoi1443奶牛逃亡(cowrun)
  7. OCP换考题了,052新考题及答案整理-第17题
  8. Mybatis遍历查询 ——foreach
  9. xtrabackup2.4 备份Precona5.6数据库,做增量备份与还原
  10. 直接可以拿去用的正则验证表达式