基于两步法的网格去噪算法顾名思义包含两个步骤:首先对网格表面的法向进行滤波,得到调整后的网格法向信息,然后根据调整后的法向更新顶点坐标位置,下面介绍三篇该类型的文章。

  [Sun et al. 2007]文章首先介绍了当前法向滤波方法以及顶点坐标更新方法,然后提出自己的法向滤波方法和顶点坐标更新方法。

  法向滤波方法:

  1.均值滤波(mean filter):ni = normalize(ΣjN(i) Aj·nj / ΣjN(i) Aj),均值滤波会破坏网格的细节特征。

  2.中值滤波(median filter):ni = arg mediannj {wj⊙∠(ni, nj) : j∈N(i)},中值滤波能够保持网格的细节特征,但当网格噪声较大时,效果并不好。

  3.α-截尾滤波(alpha-trimming filter):ni = normalize(ΣjN(i) Iα(j) ·Aj·nj),∠(ni, nj)角度值前α比例和后α比例对应的Iα(j)为0,当α = 0时等同于均值滤波,当α = 0.5时等同于中值滤波。

  4.模糊矢量中值滤波(fuzzy vector median filter):先使用矢量中值滤波nm = arg minnjkN(i) d(nj, nk) : j∈N(i)},其中d(nj, nk)为nj和nk的Lp范数或∠(nj, nk)角度值,然后再使用高斯滤波ni = normalize(ΣjN(i) nj·exp(-d(nj, nm)2/2σ2))。模糊矢量中值滤波可以得到误差较小的法向,但会增加计算量。

  5.[Sun et al. 2007]文章法向滤波方法:ni = normalize(ΣjN(i) hj·nj),权重定义为,其中N(i)为三角片fi的邻域三角片集,有两种选择,见下图,f(x) = x2,0 ≤ T ≤ 1,T的取值决定了邻域三角片N(i)中有多少三角片法向会参与计算,当T = 1时,只有与ni相等的邻域三角片法向会参与计算,而当T = 0时,所有邻域三角片法向都会参与计算。当网格有明显棱边时,T可以取相对较小值,而当网格比较光滑时,T可以取相对较大值。

Ⅰ基于顶点(vertex based)的三角片邻域;Ⅱ表示基于边(edge based)的三角片邻域

  顶点坐标更新方法:

  1.求解线性方程组:

  2.梯度下降法:

其中Nv(i)为顶点i的1环邻域顶点集。

  3. [Sun et al. 2007]文章顶点更新方法:

其中Fv(i)为顶点i的1环邻域三角片集。

效果:

  [Zheng et al. 2011]文章提出了两种三角片法向更新方法,而其顶点坐标更新方法采用和[Sun et al. 2007]文章一样的方法。

  1.Local and Iterative Scheme:

  该方法采用对法向进行双边滤波:nit+1 = Ki·ΣjN(i) wij·njt,其中N(i)为三角片fi的邻域三角片集,Ki为归一化系数,wij = ξij·Wc·Ws,ξij为三角片fj的面积Si,空间域核Wc(||ci – cj||) = exp(-||ci – cj||2/2σc2),值域核Ws(||ni – nj||) = exp(-||ni – nj||2/2σs2)。

  2. Global and Non-Iterative Scheme:

  该方法通过求解线性方程组来最小化目标函数,相对于上面的显式更新顶点坐标方法,该方法是一种对应的隐式更新顶点坐标方法,目标函数如下:

其中Ai = Si/mean({S}),上式等同于求解线性方程组,但是方程不满秩,需要加入软约束条件:Ed = Σi Ai·||ni – ni||2。最后优化目标为:argmin(1 - λ) ·Es + λ·Ed,其中λ∈[0, 1],用于控制网格的光滑程度。

效果:

 

  [Zhang et al. 2015]文章提出了一种三角片法向更新方法,该方法与[Zheng et al. 2011]文章的方法一相似,不同的是[Zheng et al. 2011]文章采用原始法向作为双边滤波中的值域信息,而[Zhang et al. 2015]文章对原始法向进行引导滤波(guided filter)得到新的法向作为值域信息。而其顶点坐标更新方法同样采用和[Sun et al. 2007]文章一样的方法。

其中Ni为三角片fi的邻域三角片集,Wi为归一化系数,Aj为三角片fj的面积,空间域核Ks和值域核Kr都为高斯核函数。

  关键如何计算三角片fi的引导法向(guidance)gi,文章提出对于三角片fi,在其周围寻找一个包含三角片fi的区域,使该区域内的三角片法向变化最小,然后将这个区域里的所有三角片法向进行加权平均作为三角片fi的引导法向。具体来说,定义Pk为与三角片fi拥有共同顶点的三角片集{fk},那么三角片fi的候选区域(candidate patch)为C(fi) = {Pk∣fi∈Pk}。对于每个区域P∈C(fi),计算区域P内三角片法向的一致性(consistency):H(P) = Ф(P)·R(P),其中Ф(P)为区域P内三角片法向的最大偏差:Ф(P) = maxfj,fkP ||nj – nk||,R(P)为区域P内相邻三角片法向的相对变化程度:,式中φ(ej) = ||nj1 – nj2||。然后选取其中一致性函数H(P)最小的区域P*,并对其中的三角片法向作面积加权平均,即得到三角片fi的引导法向gi:gi = normalize(ΣfjP* Aj·nj)。

效果:

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

参考文献:

[1] Xianfang Sun; Rosin, P.L.; Martin, R.R.; Langbein, F.C., "Fast and Effective Feature-Preserving Mesh Denoising," Visualization and Computer Graphics, IEEE Transactions, vol.13, no.5, pp.925-938, Sept.-Oct. 2007.

[2] Youyi Zheng; Hongbo Fu; Au, O.K.-C.; Chiew-Lan Tai, "Bilateral Normal Filtering for Mesh Denoising," Visualization and Computer Graphics, IEEE Transactions, vol.17, no.10, pp.1521-1530, Oct. 2011.

[3] Wangyu Zhang, Bailin Deng, Juyong Zhang, Sofien Bouaziz, Ligang Liu, "Guided Mesh Normal Filtering," Computer Graphics Forum (Proc. Pacific Graphics), 34(7): 23–34, 2015.

三维网格去噪算法(two-step framework)的更多相关文章

  1. 三维网格去噪算法(L0 Minimization)

    [He et al. 2013]文章提出了一种基于L0范数最小化的三角网格去噪算法.该思想最初是由[Xu et al. 2011]提出并应用于图像平滑,假设c为图像像素的颜色向量,▽c为颜色向量的梯度 ...

  2. 三维网格去噪算法(bilateral filter)

    受图像双边滤波算法的启发,[Fleishman et al. 2003]和[Jones et al. 2003]分别提出了利用双边滤波算法对噪声网格进行光顺去噪的算法,两篇文章都被收录于当年的SIGG ...

  3. Vertex-Based Diffusion for 3-D Mesh Denoising(三维网格去噪中基于顶点的扩散算法)

    Abstract—We present a vertex-based diffusion for 3-D mesh denoising by solving a nonlinear discrete ...

  4. Atitit.java图片图像处理attilax总结  BufferedImage extends java.awt.Image获取图像像素点image.getRGB(i, lineIndex); 图片剪辑/AtiPlatf_cms/src/com/attilax/img/imgx.javacutImage图片处理titit 判断判断一张图片是否包含另一张小图片 atitit 图片去噪算法的原理与

    Atitit.java图片图像处理attilax总结 BufferedImage extends java.awt.Image 获取图像像素点 image.getRGB(i, lineIndex); ...

  5. 三维网格形变算法(Linear rotation-invariant coordinates和As-Rigid-As-Possible)

    在三维网格形变算法中,个人比较喜欢下面两个算法,算法的效果都比较不错, 不同的是文章[Lipman et al. 2005]算法对控制点平移不太敏感.下面分别介绍这两个算法: 文章[Lipman et ...

  6. 【算法随记六】一段Matlab版本的Total Variation(TV)去噪算法的C语言翻译。

    最近看到一篇文章讲IMAGE DECOMPOSITION,里面提到了将图像分为Texture layer和Structure layer,测试了很多方法,对于那些具有非常强烈纹理的图像,总觉得用TV去 ...

  7. 三维网格分割算法(Random Walks)

    首先以一维随机游走(1D Random Walks)为例来介绍下随机游走(Random Walks)算法,如下图所示,从某点出发,随机向左右移动,向左和向右的概率相同,都为1/2,并且到达0点或N点则 ...

  8. 基于谱聚类的三维网格分割算法(Spectral Clustering)

    谱聚类(Spectral Clustering)是一种广泛使用的数据聚类算法,[Liu et al. 2004]基于谱聚类算法首次提出了一种三维网格分割方法.该方法首先构建一个相似矩阵用于记录网格上相 ...

  9. 基于模糊聚类和最小割的层次化三维网格分割算法(Hierarchical Mesh Decomposition)

    网格分割算法是三维几何处理算法中的重要算法,具有许多实际应用.[Katz et al. 2003]提出了一种新型的层次化网格分割算法,该算法能够将几何模型沿着凹形区域分割成不同的几何部分,并且可以避免 ...

随机推荐

  1. easyui日期在未加载easyui-lang-zh_CN.js出现英文的情况下加载中文的方法

    我们有时候在操作easyui的时候本来是加载了easyui-lang-zh_CN.js中文文件包,但是还是出现了英文.使得我们不得埋怨这框架咋这么不好用,其实我们仔细看看这个中文包就会发现里面很多都是 ...

  2. Android 4.4 KitKat 新特性

    New in Android 4.4 KitKat 本文是一个概览,关于KitKat,也即Android4.4的新东西,先是功能型的,之后是设计上的. 很多特性本文并没有提到,很多提到的特性也只是简短 ...

  3. Xcode 8.1 : Unable to read from device

    今天升级了Xcode 8.1,准备在iOS10.0.2的iPhone 6 Plus上调试,提示:Unable to read from device. 查看文件路径:"~/Library/D ...

  4. 扫描项目里没有使用的图片mac工具,删除没有使用的图片以减小包的体积

    [链接]netyouli/WHC_ScanUnreferenceImageToolhttps://github.com/netyouli/WHC_ScanUnreferenceImageTool

  5. 【代码笔记】iOS-3DES+Base64加密解密

    一,工程目录. 二,代码. RootViewController.m #import "RootViewController.h" #import "NSString+T ...

  6. OC中的protocol

    一. 简单使用 1. 基本用途 可以用来声明一大堆方法(不能声明成员变量) 只要某个类遵守了这个协议,就相当于拥有这个协议中的所有方法声明 只要父类遵守了某个协议,就相当于子类也遵守了 2. 格式 协 ...

  7. store 加载异常处理与加载信息提示

    var msgTip = '';   // 一定要定义在使用前,且定义为全局变量 /--------------------------------store--------------------- ...

  8. ofbiz 本地化及邮件设置126邮箱

    ofibz登陆功能有通过电子邮件找会密码的功能,但找回密码功能需要配置一个发送email的邮箱账号和smtp服务器的配置,具体配置如下: 1:在ofbiz数据库的表product_store_emai ...

  9. Learning The Bash Shell读书笔记(整理)

    最近搞了一本书 Learning Bash Shell,发现有人已经写了阅读笔记,我就在这边整理一下 来自blog:http://blog.sina.com.cn/n4mine Learning Th ...

  10. Linux:kill 进程

    在使用Linux时,出现端口占用.进程已启动(但处于不可控状态)情况时如何处理? 发现已知端口被占用时,可以使用netstat -apn | grep yourPort 来查看占用该端口的进程的pid ...