GAMES101-现代计算机图形学入门-闫令琪——Lecture 12 Geometry 3 学习笔记

Lecture 12 Geometry 3

Mesh Operations: Geometry Processing

  • Mesh subdivision
  • Mesh simplification
  • Mesh regularization
image-20210120211945364

①、Mesh Subdivision (upsampling)

image-20210121193949137

Increase resolution

网格细分。通过增加三角形面数来得到更加平滑的效果。

②、Mesh Simplification (downsampling)

image-20210121193924987

Decrease resolution; try to preserve shape/appearance

网格简化。当一个模型很复杂,但是我看这个模型的时候距离相距很远,那么看到的细节其实没有那么多,这时候就需要对网格进行简化,去掉一些边、三角形等,但是依然要维持原来的相互连接关系,不能破坏基本结构。

③、Mesh Regularization (same #triangles)

image-20210121194244584

Modify sample distribution to improve quality

三角形大小不一,长短各不相同的模型,在渲染上可能会造成很多不便。这里做一个正则化,将原来的三角形正则成大小相同的正三角形,但是同时不能丢失细节。

(一)、Subdivision

1、Loop Subdivision

Common subdivision rule for triangle meshes

First, create more triangles (vertices)

Second, tune their positions

image-20210121202218689

整个Loop细分分为两步,首先引入更多的三角形,然后再通过改变这些三角形顶点的位置来让整个模型看上去更光滑。

  • Split each triangle into four
image-20210121202311398

取三角形三边的中点并相互连接,就将一个三角形分成了四个三角形

  • Assign new vertex positions according to weights

    ​ --New / old vertices updated differently

image-20210121202424571

调整三角形顶点的位置。

将三角形的顶点区分为新的顶点和老的顶点,新的顶点即为新生成的顶点(上一步中取到的边的中点),老的顶点即为原来三角形的顶点。Loop细分将这两种不同类型的顶点,分别以不同的规则来改变他们的位置。

(Loop Subdivision并不是叫循环细分,发明这个细分方法的人的family name就叫Loop,所以就有了这个名字)

For new vertices:

image-20210121202851436

Update to: 3/8 * (A + B) + 1/8 * (C + D).

对于新的顶点(如上图白色点),会被两个三角形所共享,将共享顶点所在的这条公共边两端的两个公共顶点分别定义为A、B,然后把这两个三角形非公共的两个顶点分别定义为C、D,然后将共享顶点(上图白色点)的位置调整为3/8 * (A + B) + 1/8 * (C + D)即可(这个式子其实就是一个简单的加权平均,A和B离共享顶点近一些,所以占的比例相对较大,而C和D离共享顶点远一些,所以占的比例相对较小)。

For old vertices (e.g. degree 6 vertices here):

image-20210121203428690

Update to: (1 - n*u) * original_position + u * neighbor_position_sum

n:vertex degree

u:3/16 if n=3,3/(8n) otherwise

对于老的顶点(如上图白色点),周围的老顶点会对这个顶点有一定的影响。Loop细分规定这个要计算的老顶点(上图白色点)一部分受周围老顶点的影响,一部分保持自己的位置属性。在这里我们定义一个n,为顶点的度(这个顶点连接的边的数量),再定义一个u,这个u仅仅是一个与顶点的度有关的数。得到以下公式:(1 - n*u) * original_position + u * neighbor_position_sum。从这个式子可以看到,当顶点的度很大(连了好多三角形),那么这个顶点基本就可以由周围的老顶点决定位置,当顶点的度很小(连接的三角形很少),那么这个顶点由自己原来位置决定更新后位置的比重就会增大。

2、Catmull-Clark Subdivision (General Mesh)

刚刚的Loop Subdivision仅仅可以针对全部都是三角面的网格。而Catmull-Clark Subdivision适用于更普遍的情况,无论是四边面还是三角面都可以很好地进行细分处理。

image-20210121204507690

首先我们定义Non-quad face,所有不是四边面的网格形状都被称作非四边形面。

其次我们再定义奇异点(极点),所有度不为4的点都被称为奇异点。

Each subdivision step:

①、Add vertex in each face

②、Add midpoint on each edge

③、Connect all new vertices

对于每一个面,首先取这个面中心的点,然后取这个面的各个边的中点,最后把边上的中点和面中心的点连起来。

image-20210121204831690

如上图,即为经过Catmull-Clark细分后的样子。

After one subdivision:

How many extraordinary vertices? 共有4个奇异点

What are their degrees? 原来是度是5的奇异点现在的度还是5,新引入的奇异点由于要与三角面上的每一条边的中点相连,因此度为3

How many non-quad faces? 没有非四边形面了,全部都为四边形面(细分的过程中每一个非四边形面都会引入一个奇异点,然后非四边形面就消失了)

image-20210121210518706image-20210121210529787

再次细分后,面会越来越光滑。

FYI: Catmull-Clark Vertex Update Rules (Quad Mesh)

image-20210121210701366

Catmull-Clark细分后对点的位置的更新分三种:

第一种是对于面的中心点f的更新,第二种是对于边的中心点e的更新,第三种是对于老的顶点v的更新。公式如上图所示。

Convergence: Overall Shape and Creases

image-20210121211240085

Loop Subdivision仅能用于三角形面的网格,Catmull-Clark Subdivision可以用于任何形状组成的网格。

(二)、Mesh Simplification

Goal: reduce number of mesh elements while maintaining the overall shape

image-20210121211425073

How to compute?

不同情况下要用不同面数的模型,那么如何去计算对网格的简化?

Collapsing An Edge

  • Suppose we simplify a mesh using edge collapsing
image-20210121211548366

这里提供边坍缩的方法。

边坍缩:形象的说明的话,即为一条边两端连着两个顶点,将这两个顶点往中间一捏,变成一个点,这个操作即为边坍缩。

Quadric Error Metrics(⼆次误差度量)

  • How much geometric error is introduced by simplification?
  • Not a good idea to perform local averaging of vertices
  • Quadric error: new vertex should minimize its sum of square distance (L2 distance) to previously related triangle planes!
image-20210121211842407

如上图左图,假设要简化上面三个顶点,变成一个顶点,该把这个顶点放在哪里,才能保证简化后的蓝色三角形与原本灰色多边形基本保持轮廓的一致?这里引入二次误差度量概念:我们希望把这个顶点放某个位置上,可以最小化二次误差。在此处的意思就是:把这个顶点放置在某个位置上,使得这个顶点到各个面(如上图右图,在这里看上去像是边)的距离的平方和达到最小。

Quadric Error of Edge Collapse

  • How much does it cost to collapse an edge?

  • Idea: compute edge midpoint, measure quadric error

  • Better idea: choose point that minimizes quadric error

  • More details: Garland & Heckbert 1997

对于整个模型有很多条边,假设如果坍缩一条边,并且算出把这个坍缩后的点放在最佳的位置上会得到一个多大的二次度量误差。对于整个模型而言,每次肯定都是要坍缩二次度量误差最小的边。

Simplification via Quadric Error

Iteratively collapse edges

Which edges? Assign score with quadric error metric*

  • approximate distance to surface as sum of distances to planes containing triangles
  • iteratively collapse edge with smallest score
  • greedy algorithm… great results!

先给每个边打上一个分数,这个分数就是这个边的二次度量误差,从小的开始一个个进行坍缩。

但是问题是,如果坍缩了一条边,有一些其他的边的位置要跟着这条坍缩的边变化,那么这些边的二次度量误差就会随之发生变化。

因此这里我们要通过一种数据结构,既可以每次取到二次度量误差的最小值的边,又可以动态地以最小的代价去更新其他的受影响的元素。那么这里要使用的数据结构就是堆(优先队列)。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值