几何的隐式表示与显示表示
Many Ways to Represent Geometry
Implicit 隐式表示
- algebraic surface
- level sets
- distance functions
- …
Explicit 显示表示
- point cloud
- polygon mesh
- subdivision, NURBS
- …
Each choice best suited to a different task/type of geometry
Implicit 隐式表示
隐式表示就是告诉我们点满足某种特定的关系,而不是告诉我们点具体在哪。
More Implicit Representations in Computer Graphics
Algebraic Surfaces
直接用数学公式表示,最大的问题是不直观,比如右边的心形很难直观的想出来,而更复杂的情况就很难表示,比如下面的奶牛就很难用公式表示出来。
data:image/s3,"s3://crabby-images/bb29d/bb29d72cd182f3f1b2ae8cd0ee9fdc79b69a7d49" alt=""
Constructive Solid Geometry
通过一系列基本几何的基本运算来定义新的几何。
比如下面圆柱A、球B就是基本几何,通过类似于集合的交、并、差运算,就可以形成新的几何。
data:image/s3,"s3://crabby-images/24d98/24d98c8ffdbb52184ae79afa2aea94e42ddf07cb" alt=""
Distance Functions
不直接描述几何的表面,而是描述空间中任意一个点到物体表面的最小距离。
物体内距离为负,物体表面距离为零,物体外距离为正。
data:image/s3,"s3://crabby-images/2a898/2a898ed06ec121fdb59a02fd6537cf16c0dd3d10" alt=""
可以将两个距离函数做blending,得到一个新的几何物体。
data:image/s3,"s3://crabby-images/b5e03/b5e03fe29ec9687dd3de82dc3b0b74b80bf92418" alt=""
距离函数的表示能力非常强,比如下图的例子,它将物体之间的联系圆滑的过度过去。
data:image/s3,"s3://crabby-images/4dd85/4dd855ee2082884dcfd3e2b9fcfbc0125664d29f" alt=""
Level Set Methods
如果距离函数不方便写成解析的形式,还可以通过水平集的方法表示出来。水平集和上面距离函数的区别仅仅是表示形式的区别。
可以通过双线性插值等方法,得到$f(x)=0$的位置。
地理上的等高线和水平集比较类似,一条等高线就是$f(x)$等于某个高度的地方。
data:image/s3,"s3://crabby-images/3e812/3e812d0df2635c6d128895cff6d7d75e63cbfe25" alt=""
水平集不一定要定义在二维的格子上,也可以定义在三维的格子上,下面就是一个例子。
水平集根据组织密度,构成了三维体积模型。
data:image/s3,"s3://crabby-images/1bbd5/1bbd5501f8f6fe1b948a214ff1ab46cc3bbf53c3" alt=""
Fractals
几何还有一种特殊的方法,叫做fractal(分形)。
分形是一个自相似的过程,包括在不同的尺寸上,指的是自己的一个部分和它的整体长得非常像,类似于递归。
data:image/s3,"s3://crabby-images/e7fda/e7fdaa7feda6755a8823f6c2704708576e8b2ab5" alt=""
Pros & Cons
Pros:
compact description (e.g., a function)
certain queries easy (inside object, distance to surface)
将点代入$f(x,y,z)$,如果小于零在里面,大于零在外面,等于零在面上。例如下面这个例子:
good for ray-to-surface intersection (more later)
for simple shapes, exact description / no sampling error
easy to handle changes in topology (e.g., fluid)
Cons:
difficult to model complex shapes
sampling can be hard
Explicit 显示表示
显示表示指的是直接给出所有的点,或者通过参数映射给出所有的点。下图是通过参数映射表示点的例子。
data:image/s3,"s3://crabby-images/08e10/08e1015b37d61391edf2e2b94ae7b8db3dd0d2ac" alt=""
Many Explicit Representations in Graphics
Point Cloud
data:image/s3,"s3://crabby-images/bd06d/bd06d48ed1cd766a66152cb0f58cee800b5171a0" alt=""
Polygon Mesh
data:image/s3,"s3://crabby-images/d58d0/d58d0954cd562668403bd1324488e2a35e408cbb" alt=""
The Wavefront Object File (.obj) Forma
data:image/s3,"s3://crabby-images/ea588/ea58815ce729e92a7934ecbb2d8b53317b0152b8" alt=""
Pros & Cons
Pros:
采样很简单,将所有的UV代入就能得到所有的点了
data:image/s3,"s3://crabby-images/e2501/e25019dbb1dfaad6d5486008a4f1d3c197e604b0" alt=""
Cons:
判断点在表面的里面还是外面很困难
data:image/s3,"s3://crabby-images/b3743/b3743b4dce34548edb0d452c6b00d04c7d681ddf" alt=""
思考
- 在隐式表示Constructive Solid Geometry部分,这些运算如何使用解析的形式表示出来?如果基本几何之间只使用一部分做运算(两个基本几何的中心不对齐),又怎么表示?
- 在显示表示中,可以通过映射表示几何物体,比如$f(u, v) = ((2 + cos u) cos v,(2 + cos u) sin v,sin u)$就表示了一个圆环,这样从二维向三维映射的方式能够表示所有的几何物体吗?如果是一头奶牛,可以使用$f(u,v)$的映射表示吗?如果圆环的位置移动了,或者姿态改变了,还可以通过二维向三维的映射表示吗?(也许可以先计算几何当前位置到某个“标准位置”的映射关系,即三维到三维的映射,然后把这个映射再反馈到二维到三维的映射中?这应该只是一个线性的变换???)