网格简化算法(二)

网格简化算法(二)边折叠

效果展示:
在这里插入图片描述
可见,折叠边(u, v),三角形1和2消失

算法思路:
在这里插入图片描述

具体解释

1、对每个顶点定义一个4x4的对称误差矩阵。
定义顶点到共享自己的面的距离的平方和为顶点到这些面的误差。
在这里插入图片描述
由于初始情况下,顶点都是在那些面上的,所以初始误差均为0。Q矩阵就是点所有相邻面的二次误差矩阵的和。

2、收缩一条边(v1, v2),则需要计算新的顶点位置。收缩一条边的Q可以确定:Qbar = Q1+ Q2。但是位置的选择需要计算,一种选择是从v1,v2,(v1 + v2)/2这三个位置上找,分别计算他们的Δ(v)。最小的那个就是我们要寻找的办法。另一种选择就是通过数值计算Δ(vbar)最小来寻找位置,由于Δ的表达式是一个二次项形式,因此令一阶导数为0
在这里插入图片描述
等价于求解:

在这里插入图片描述
其中qij为矩阵Qbar中对应的元素。如果系数矩阵可逆,那么通过求解上述方程就可以得到新顶点vbar的位置,如果系数矩阵不可逆,就通过第一种简单策略来得到新顶点vbar的位置。

3、由此得到所有边的cost。维护一个最小堆,每次取出堆顶元素,删除边表中该边,将新的顶点加入顶点表,当然,如果新的顶点在顶点表中,则不需要加入了。同时更新一下所有顶点的Q矩阵。

整理一下伪代码

1、建立边表和顶点表、面表
2、使用点到面的距离公式,建立Q矩阵
3、对所有的边计算cost,建立(维护)最小堆
4、pop出堆顶,删除边,更新顶点表、面表、Q矩阵
5、重复3 - 4直到面数小于阈值

Reference

[1] 拉风小宇博主
[2] https://www.cnblogs.com/shushen/p/5311828.html
[3] 百度百科

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值