网格去噪算法(two-step framework)

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

  [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)。

效果:

欢迎大家一起探讨计算机图形学算法问题,邮箱:[email protected]

本文为原创,转载请注明出处: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.

时间: 2024-12-14 04:33:20

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

网格去噪算法(bilateral filter)

受图像双边滤波算法的启发,[Fleishman et al. 2003]和[Jones et al. 2003]分别提出了利用双边滤波算法对噪声网格进行光顺去噪的算法,两篇文章都被收录于当年的SIGGRAPH,至今引用超500余次.虽然从今天看两篇文章的去噪效果还不算非常好,但是其中的思想是值得学习的.图像双边滤波算法可以参考http://blog.csdn.net/abcjennifer/article/details/7616663,图像双边滤波器由空间域核与值域核组成,在图像的特征区域,自

网格聚类算法综述

网格聚类算法综述 (1)STING STING(Statistical Information Grid)是一种基于网格的多分辨率聚类技术它将空间区域划分为矩型单元.针对不同级别的分辨率,通常存在多个级别的矩形单元,这些单元形成了一个层次结构:高层的每个单元被划分为多个低一层的单元.每个网格单元属性的统计信息(例如平均值.最大值和最小值)被预先计算和存储.这些统计信息对于下面描述的查询处理是有用的. STING有几个优点:(1)由于存储在每个单元中的统计信息提供了单元中的数据不依赖查询的汇总信息

python去噪算法

<programming computer vision with python >中denoise 算法有误,从网上好了可用的代码贴上,以便以后使用. 书中错误的代码: def denoise(im,U_init,tolerance=0.1,tau=0.125,tv_weight=100): m,n = im.shape U = U_init Px = im Py = im error = 1 while (error > tolerance): Uold = U GradUx = r

网格测地线算法(Geodesics in Heat)附源码

测地线又称为大地线,可以定义为空间曲面上两点的局部最短路径.测地线具有广泛的应用,例如在工业上测地线最短的性质就意味着最优最省,在航海和航空中,轮船和飞机的运行路线就是测地线.[Crane et al. 2013]提出了利用热运动方程来计算网格测地线的方法,可以想象一下,当一根烫的针尖接触到曲面上的一点时,热量会随着时间的推移而扩散,测地距离因此可以和热运动相联系.具体算法过程如下图所示: 第一步:热运动方程用来描述热的传播状态: 将热运动方程离散化并整理后得到: 其中:id为单位矩阵,t为时间

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

最近看到一篇文章讲IMAGE DECOMPOSITION,里面提到了将图像分为Texture layer和Structure layer,测试了很多方法,对于那些具有非常强烈纹理的图像,总觉得用TV去燥的方法分离的结果都比其他的方法都要好(比如导向.双边),比如下图: 再比如:   可见TV可以把纹理很好的提取出来. 现在应该能找到很多的TV代码,比如IPOL上就有,详见http://www.ipol.im/pub/art/2013/61/. 我在其他地方也见过一些,比如这里: http://y

网格形变算法(Gradient-Based Deformation)

将三角网格上的顶点坐标(x,y,z)看作3个独立的标量场,那么网格上每个三角片都存在3个独立的梯度场.该梯度场是网格的微分属性,相当于网格的特征,在形变过程中年不发生变化(避免网格形变后畸形).那么当用户拖拽网格上的控制点集时,网格形变问题即变为求解以下式子: 根据变分法,上式最小化即求解泊松方程: 其中Φ为待求的网格形变后坐标,w为网格形变后的梯度场. 上式可以进一步表示为求解稀疏线性方程组: 其中L为网格的拉普拉斯算子,b为梯度场w在网格顶点处的散度值. 问题的关键是如何得到网格形变后的梯度

网格测地线算法(Geodesics in Heat)

[Crane et al. 2013]提出了利用热运动方程来计算网格测地线的方法,具体算法过程如下图所示: 第一步:热运动方程用来描述热的传播状态: 将热运动方程离散化并整理后得到: 其中:id为单位矩阵,t为时间间隔,Δ为离散Laplacian算子,ut为t时刻的热状态,u0为初始时刻的热状态. 第二步:第一步计算得到的热梯度方向与测地距离的梯度方向相同,由Eikonal方程知道测地距离的梯度为单位向量,于是通过归一化热梯度我们得到测地距离的梯度: 第三步:得到测地距离的梯度之后,测地线问题即

网格形变算法(Laplacian-Based Deformation)

网格上顶点的Laplace坐标(均匀权重)定义为:,其中di为顶点vi的1环邻域顶点数. 网格Laplace坐标可以用矩阵形式表示:△=LV,其中,那么根据网格的Laplace坐标通过求解稀疏线性方程组可以得到网格的顶点坐标. 基于网格Laplace形变算法的思想:网格上顶点的Laplace坐标作为网格的细节特征,其在网格形变前后的局部坐标系内不发生变化.Laplace形变问题可以用如下数学优化形式表达,那么问题的关键是如何得到网格形变后的Laplace坐标,或者说是每个顶点Laplace坐标的

NLM去噪算法实现

简介 本篇主要是对NLM去噪算法的实现总结. 参考论文:点击打开链接 基本原理 该算法的基本原理是:假设同一副图像上,有着很多相似的纹理:因此在有噪声的区域,可以通过某种方式情况下,将相似的纹理区域来替换噪声区域. 从而达到较好的去噪效果,并且不太多的损失细节. 具体实现 1.该算法需要遍历整个原图像:首先取出一个原图像pixel,以该pixel坐标为中心,圈出一大.一小两个矩形.大的矩形表示纹理替换搜索区域R,小的 矩形表示待处理pixel的纹理区域L. R和L的size关系可以参考论文描述: