在逆向工程中,由于设备或模型的原因,我们获取得到的三维模型数据往往并不完整,从而使得生成的网格模型存在孔洞,这对后续的模型分析会造成影响。下面介绍一种基于径向基函数(RBF:Radial Basis Function)的三角网格补洞方法。

Step 1:检测孔洞边界

  三角网格是由一系列顶点(V)以及由这些顶点所构成的三角面片(F)所组成,由三角面片可以得到网格的边(E)。通常一条边连接两个三角面片,这种边称为网格内部边,而如果某条边仅连接一个三角面片,那么称这条边为网格边界边,所有的边界边按顺序连接之后就形成了网格的孔洞。

Step 2:初始化网格

  为了使孔洞填充简单、健壮,可以采用最小角度法进行网格修补,具体步骤如下:

  (1)得到孔洞边界点信息,计算边界边长度的平均值l

  (2)计算每个边界点的两条相邻边的夹角大小。

  (3)找出具有最小夹角的边界点,计算它的两个相邻边界点的距离s,判断s < 2×l是否成立:若成立,则按下图所示增加一个三角形,若不成立则增加两个三角形。

  (4)更新边界点信息。

  (5)判断孔洞是否修补完整,若未完整,转(2),否则结束。

Step 3:最小二乘网格

  初始化补洞得到的网格质量不是很好,我们需要优化网格顶点的位置,优化的条件是:

其中di为顶点vi的1环邻域顶点数。

  上式可以用一个线性方程组来描述:LV = 0,其中L是Laplace矩阵,具体形式为,矩阵L的秩等于n – k,n为网格顶点的数目,k为网格连通区域的个数,如果网格是全连通的,那么矩阵L的秩是n – 1。因此如果我们要使方程有解,需要加入m(m ≥ k)个控制顶点坐标vs作为方程的边界条件,在实际中我们将初始化网格的边界顶点作为控制顶点。

  其实上述线性方程组的求解等价于如下能量函数最小化的求解:

  能量函数的第一部分是使得网格顶点尽量光滑,即每个顶点位于其1环邻域顶点的中心,第二部分是为了控制顶点的位置满足要求。

  最小二乘网格的优势是能够生成高质量的光滑网格,生成过程仅需要网格的拓扑连接关系和少数控制点的坐标信息。

Step 4:径向基函数(RBF)隐式曲面

  径向基函数是一个仅依赖于离控制点c距离的函数,即h(x,c) = h(||x - c||),距离通常是欧式距离,也可以是其他形式距离。径向基函数网络是一个三层BP网络,其可以表示为多个基函数的线性组合:

  下面列出2个最常用的基函数形式:

  (1)Gaussian:h(r) = e-(εr)2

  (2)Polyharmonic spline:h(r) = rk,k = 1、3、5、… 或h(r) = rkln(r),k = 2、4、6、…

  利用径向基函数网络并通过给定控制点xi和对应的值fi之后,可以求解得到网络中的系数λi,因此径向基函数网络能够解决空间散乱数据点的平滑插值问题,函数的零等值面就是我们要求的曲面。

  在实际求解时函数f(x)表达式中通常会增加一个一次多项式P(x),如下:

,其中:

  将控制点位置xi和值fi代入函数f(x)可以得到如下方程,求解之后即可确定隐式曲面f(x)。

  控制点xi可分为三类:

  (1)边界控制点:曲面通过的点,f(xi) = 0

  (2)外部控制点:将边界控制点沿法向正方向移动一小段距离而得到的控制点,取f(xi) = -1

  (3)内部控制点:将边界控制点沿法向负方向移动一小段距离而得到的控制点,取f(xi) = 1

  计算时我们选择的基函数为h(r) = r3,其实此时隐式曲面函数满足Δ3f = 0,将基函数代入后得到隐式曲面的表达式如下:

function options = RBF_Create(x, y, type)
% x: input data; y: input data value
options = [];
options.nodes = x;
switch type
case 'linear'
options.phi = @rbfphi_linear;
case 'cubic'
options.phi = @rbfphi_cubic;
end [n, dim] = size(x);
A = zeros(n,n);
for i = :n
r = normrow(bsxfun(@minus, x(i,:), x));
temp = feval(options.phi, r);
A(i,:) = temp';
A(:,i) = temp;
end
% Polynomial part
P = [ones(n,) x];
A = [ A P
P' zeros(dim+1, dim+1)];
B = [y; zeros(dim+, )]; coeff = A\B;
options.coeff = coeff;
end % Radial Base Functions
function u = rbfphi_linear(r)
u = r;
end
function u = rbfphi_cubic(r)
u = r.*r.*r;
end

Step 5:牛顿插值

  为了得到插值隐式曲面的网格,我们需要把最小二乘网格的顶点投射到隐式曲面上,这里我们采用牛顿迭代法:

  最小二乘网格的顶点位置作为迭代初始条件,当||xk+1 – xk|| < ε时,迭代停止,ε为设定的误差。上式中梯度表达式如下:

效果:

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

参考文献:

[1] Olga Sorkine and Daniel Cohen-Or. 2004. Least-Squares Meshes. In Proceedings of the Shape Modeling International 2004 (SMI '04). IEEE Computer Society, Washington, DC, USA, 191-199.

[2] Greg Turk and James F. O'Brien. 1999. Shape transformation using variational implicit functions. In Proceedings of the 26th annual conference on Computer graphics and interactive techniques (SIGGRAPH '99). ACM Press/Addison-Wesley Publishing Co., New York, NY, USA, 335-342.

[3] 袁天然. 三角网格模型光顺简化和缝补技术的研究及应用[D]. 南京航空航天大学, 2007.

三维网格补洞算法(Radial Basis Function)的更多相关文章

  1. 三维网格补洞算法(Poisson Method)

    下面介绍一种基于Poisson方程的三角网格补洞方法.该算法首先需要根据孔洞边界生成一个初始化补洞网格,然后通过法向估算和Poisson方程来修正补洞网格中三角面片的几何形状,使其能够适应并与周围的原 ...

  2. 三维网格补洞算法(Poisson Method)(转载)

    转载:https://www.cnblogs.com/shushen/p/5864042.html 下面介绍一种基于Poisson方程的三角网格补洞方法.该算法首先需要根据孔洞边界生成一个初始化补洞网 ...

  3. 【Radial Basis Function Network】林轩田机器学习技法

    这节课主要讲述了RBF这类的神经网络+Kmeans聚类算法,以及二者的结合使用. 首先回归的了Gaussian SVM这个模型: 其中的Gaussian kernel又叫做Radial Basis F ...

  4. Orthogonal Least Squares Learning Algorithm for Radial Basis Function Networks

    Orthogonal Least Squares Learning Algorithm for Radial Basis Function Networks S. Chen, C. F. N. Cow ...

  5. 机器学习技法:14 Radial Basis Function Network

    Roadmap RBF Network Hypothesis RBF Network Learning k-Means Algorithm k-Means and RBF Network in Act ...

  6. 机器学习技法笔记:14 Radial Basis Function Network

    Roadmap RBF Network Hypothesis RBF Network Learning k-Means Algorithm k-Means and RBF Network in Act ...

  7. Coursera台大机器学习技法课程笔记14-Radial Basis Function Network

    将Radial Basis Function与Network相结合.实际上衡量两个点的相似性:距离越近,值越大. 将神经元换为与距离有关的函数,就是RBF Network: 可以用kernel和RBF ...

  8. OpenCascade B-Spline Basis Function

    OpenCascade B-Spline Basis Function eryar@163.com Abstract. B-splines are quite a bit more flexible ...

  9. [Machine Learning] 浅谈LR算法的Cost Function

    了解LR的同学们都知道,LR采用了最小化交叉熵或者最大化似然估计函数来作为Cost Function,那有个很有意思的问题来了,为什么我们不用更加简单熟悉的最小化平方误差函数(MSE)呢? 我个人理解 ...

随机推荐

  1. 用c#开发微信(5)自定义菜单设置工具 (在线创建)

    读目录 1 使用 2 原理 3. 错误 上次写了<用c#开发微信 (4) 基于Senparc.Weixin框架的接收事件推送处理 (源码下载)>,有园友问到如何创建菜单的问题,今天就介绍下 ...

  2. Asp.net 面向接口可扩展框架之“Mvc扩展框架及DI”

    标题“Mvc扩展框架及DI”有点绕口,我也想不出好的命名,因为这个内容很杂,涉及多个模块,但在日常开发又密不可分 首先说Mvc扩展框架,该Mvc扩展就是把以前的那个Mvc分区扩展框架迁移过来,并优化整 ...

  3. 从头开始搭建一个mybatis+postgresql平台

         最近有个项目的数据库使用postgresql,使用原生态的mybatis操作数据,原生态的没什么不好,只不过国内有个tk.mybatis的工具帮助我们做了很多实用的事情,大多数情况下我们需要 ...

  4. MSSQL 分页

    使用数据库分页返回用户数据有如下好处:1.减少服务器磁盘系统地读取压力2.减少网络流量,减轻网络压力3.减轻客户端显示数据的压力4.提高处理效率. 一般而言分页处理分为两种:应用程序中的分页(查询出所 ...

  5. 搭建基于 STM32 和 rt-thread 的开发平台

    我们需要平台 如果说,SharePoint 的价值之一在于提供了几乎开箱即用的 innovation 环境,那么,智能设备的开发平台也一样.不必每次都从头开始,所以需要固定的工作室和开发平台作为创新的 ...

  6. centos虚拟机复制移动后网络配置无效

    移植Centos虚拟机后无法联网解决1.迁移以后,会存在其中一个网卡无法启动(eth0 or eth1) [root@ ~]# ifup eth0 WARNING: Deprecated config ...

  7. SharePoint 2013 托管导航及相关配置 <二>

    本文的思路是使用JQuery重写SharePoint自带托管导航的样式,其实思路和脚本都非常简单,引用一下JQuery脚本,然后重写导航的样式,把脚本放到母版页中,即可.当然,使用JQuery可以做很 ...

  8. Android 6.0 权限管理最佳实践

    博客: Android 6.0 运行时权限管理最佳实践 github: https://github.com/yanzhenjie/AndPermission

  9. IOS RunLoop浅析 二

    上一篇我们说了runloop 的几种模式,那么我们在模式中又要做些什么呢??? 模式中有三个模块: 事件源(输入源) Source Source: 按照官方文档分类 Port-Based Custom ...

  10. HashSet 浅析示例

    * 1.继承自抽象类 AbstractSet,实现接口 Set.Cloneable.Serializable: * 2.元素无顺序: * 3.元素不可重复: * 4.采用哈希算法插入数据,插入速度快: ...