Shape Analysis课程笔记07-Discrete Surface Curvature
这个系列是MIT 6.838: Shape Analysis的同步课程笔记。本课程会介绍几何方法在图形学、机器学习、计算机视觉、医疗图像以及建筑设计等相关领域的原理和应用。本节主要介绍离散网格上计算各种曲率的相关方法。
Applications of Curvature
在上一节中我们介绍了连续曲面上的曲率。具体地,曲面上最重要的两个曲率分别是Gauss曲率和平均曲率,它们与主曲率以及曲面的第二基本形式有着密切的关系。
data:image/s3,"s3://crabby-images/1ec65/1ec65371477dee7b681da662e3a01635d1d829f5" alt=""
曲面上的曲率在工程中有非常多的应用。比如说我们可以把Gauss曲率和平均曲率作为曲面形状的描述子、利用曲率来重建曲面、对曲面进行滤波、指导渲染过程、重新网格化(remeshing)等。
data:image/s3,"s3://crabby-images/80a24/80a24044d77032a9904227a61d798e6a4fb1b9d7" alt=""
data:image/s3,"s3://crabby-images/81d21/81d21c614b4f0fc3c37c8c9d1bf4b5643654f4c3" alt=""
data:image/s3,"s3://crabby-images/fec1c/fec1c35990e86337c16f3da893bba0481d4a662a" alt=""
data:image/s3,"s3://crabby-images/a12c8/a12c88d1ccf06af0e357c8907f7d695f309b571e" alt=""
data:image/s3,"s3://crabby-images/f0884/f0884af6d6851fb83eec9e8c8c518bc73158790d" alt=""
data:image/s3,"s3://crabby-images/b1323/b1323bd1740b0c0d6126e8960ad4c208264d8c71" alt=""
Approximating Curvature
Challenge on Meshes
在离散网格上计算曲率的难点在于曲率的定义依赖于曲面上的导数,而在离散网格上每个面片都是一个平面。因此对于离散曲面的曲率我们只能使用一些近似方法来计算。
data:image/s3,"s3://crabby-images/d2c0e/d2c0ec004540842867ec45b40d57c84601ee5896" alt=""
data:image/s3,"s3://crabby-images/b2a21/b2a21650744d84e7ae8f6f61ee1ea6e5d815e079" alt=""
Local Tensor Methods
早期计算离散曲面上曲率的方法是直接估计网格上的第二基本形式,然后再导出Gauss曲率和平均曲率。Taubin指出在光滑曲面上可以利用一个矩阵来\(M_\mathbf{p}\)来估计曲率:
data:image/s3,"s3://crabby-images/9bca6/9bca6bc4794e8a089a6cdd5072df04751592bbb0" alt=""
进一步可以证明\(M_\mathbf{p}\)的特征向量分别为法向\(\mathbf{n}\)以及两个主方向\(\mathbf{t}_1\)和\(\mathbf{t}_2\),而其特征值与曲面的主曲率密切相关:
data:image/s3,"s3://crabby-images/d1c39/d1c399934821f06d59c749b6830dca9267e11cfd" alt=""
对于离散的情况,我们只需要把积分改成求和并替换掉相应的被积项即可:
data:image/s3,"s3://crabby-images/5dda2/5dda2dd2f0d2c44959c2c15f497a96fc86995d47" alt=""
data:image/s3,"s3://crabby-images/683a5/683a5a4d93dbe87077e93ed91419526db0e516d6" alt=""
这里我们简单对离散的过程进行一下推导。对于曲面上的曲线\(\gamma(s)\),首先根据Taylor展开有:
\[\gamma(s) = \mathbf{p} + \mathbf{T}(0) s + \frac{1}{2} \kappa_{\gamma(0)} \mathbf{N}(0) s^2 + O(s^3)\]上式表明:
\[\Vert \gamma(s) - \mathbf{p} \Vert_2^2 = s^2 + O(s^3)\] \[2 \mathbf{n}_\mathbf{p}^T (\gamma(s) - \mathbf{p}) = \kappa_{\theta} s^2 + O(s^3)\]因此可以得到方向曲率的计算公式:
\[\begin{aligned} \kappa_{\theta} &= \frac{2 \mathbf{n}_\mathbf{p}^T (\gamma(s) - \mathbf{p})}{s^2} + O(s) \\ &= \frac{2 \mathbf{n}_\mathbf{p}^T (\gamma(s) - \mathbf{p})}{\Vert \gamma(s) - \mathbf{p} \Vert_2^2 + O(s^3)} + O(s) \\ &= \frac{2 \mathbf{n}_\mathbf{p}^T (\gamma(s) - \mathbf{p})}{\Vert \gamma(s) - \mathbf{p} \Vert_2^2} + O(s) \end{aligned}\]data:image/s3,"s3://crabby-images/8db24/8db24d6a55be3f1905f8694d41b6d7b1bf717b20" alt=""
Taubin方法的一个缺陷在于它对曲率的估计容易受到局部噪声的影响。由于Taubin方法是基于Taylor展开来推导的,当网格不够稠密时它对曲率的估计往往不够准确。
data:image/s3,"s3://crabby-images/8aade/8aade3bc42ce5355de547d772c8f0a33d30348ba" alt=""
在一些更现代的方法中,我们会根据实际任务的需求来设计曲率的估计方法。
data:image/s3,"s3://crabby-images/8819e/8819e1ff3819899827a722f073b4612e8be8564d" alt=""
data:image/s3,"s3://crabby-images/5970e/5970e605989c2270f08299d8d7d8fa881ca1e216" alt=""
Direct Approximation of \(\mathbf{II}\)
假设已知切平面上的基向量\(\mathbf{u}\)和\(\mathbf{v}\),此时曲面的第二基本形式\(\mathbf{II}\)可以表示为一个矩阵。对于切平面上的向量\(\mathbf{w} = c^1 \mathbf{u} + c^2 \mathbf{v}\),可以利用矩阵形式的\(\mathbf{II}\)来计算\(\mathbf{w}\)方向的shape operator。
data:image/s3,"s3://crabby-images/45122/45122adefd1e7f5d14e4fcaf49ac887690f1d47f" alt=""
因此在离散网格上我们可以构造一个线性系统来求解每个三角形上的\(\mathbf{II}\):
data:image/s3,"s3://crabby-images/349ec/349ec5675d775d3b89270abd1af32327d1f2deee" alt=""
最后利用切平面的相对旋转和加权平均的方法就可以得到每个顶点上的\(\mathbf{II}\):
data:image/s3,"s3://crabby-images/d7eaf/d7eaf0ef5e4f92dfaf7991ce6f116a0e1d661163" alt=""
Structure-Preserving Methods
除了上面介绍的方法我们还可以利用曲率的性质来直接推导离散网格上的曲率计算公式。
data:image/s3,"s3://crabby-images/2f72f/2f72ffea390d923edfc3d2a4db3d9cc19cb6c2f6" alt=""
data:image/s3,"s3://crabby-images/f5079/f507980d0a3a9c00a5ece379d5a114263c6f4cef" alt=""
Structure-Preserving Gaussian Curvature
Gauss-Bonnet定理(Gauss-Bonnet theorem)是Gauss曲率最重要的性质之一,它指出Gauss曲率的积分是一个拓扑不变量。
data:image/s3,"s3://crabby-images/84892/84892f0555792ff0fa0760fbe11a08e04f30469c" alt=""
利用Gauss-Bonnet定理我们可以推导出离散Gauss曲率的表达式。首先定义顶点上的Voronoi cell:
data:image/s3,"s3://crabby-images/38311/3831143164bb35a6656db1aff3527ab792aa9dbe" alt=""
在Voronoi cell上对Gauss曲率进行积分有:
\[\int_V K dA = 2 \pi \chi(V) - \oint_{\partial V} \kappa_g ds\]可以证明在Voronoi cell上欧拉示性数满足\(\chi(V) = 1\),而测地曲率的积分在每个三角形上等于转角\(\varepsilon_i\)。因此有:
\[\int_V K dA = 2 \pi - \sum_i \varepsilon_i = \int_V K dA = 2 \pi - \sum_i \theta_i\]即Gauss曲率在顶点Voronoi cell上的积分等于\(2\pi\)与顶点内角和的差,称为angle defect:
data:image/s3,"s3://crabby-images/43f0b/43f0b39d24b332ee4c448d7c4c938487c8cdfe6f" alt=""
类似地,我们也可以推导出离散Gauss-Bonnet定理(discrete Gauss-Bonnet theorem):
data:image/s3,"s3://crabby-images/4fe6c/4fe6c22befa37bd8b113527a49b8b48d906d421e" alt=""
Structure-Preserving Mean Curvature
对于曲线来说,\(\kappa \mathbf{N}\)是缩短曲线长度最快的方式。
data:image/s3,"s3://crabby-images/edc33/edc330131e727a13c43a9304e17833bf8e04e6ca" alt=""
类似地,mean curvature normal则可以理解为曲面面积的梯度。
data:image/s3,"s3://crabby-images/350fb/350fbf1ec69bdff7dda6cfcf21321f936d5147ea" alt=""
对于离散网格,我们可以认为曲面的面积是一个网格到实数的映射:
data:image/s3,"s3://crabby-images/cf7c7/cf7c70fb9a372895307d4ef10fe993799d4e8a43" alt=""
这样就可以利用mean curvature normal的性质来推导离散曲面上的平均曲率。首先考虑空间中的一个三角形,我们定义一组正交基分别为\(\mathbf{e}\),\(\mathbf{e}_\perp\)以及\(\mathbf{n}\)。此时\(\mathbf{p}\)点的坐标以及三角形的面积\(A(\mathbf{p})\)可以表示为:
\[\mathbf{p} = p_e \mathbf{e} + p_\perp \mathbf{e}_\perp + p_n \mathbf{n}\] \[A(\mathbf{p}) = \frac{1}{2} b \sqrt{p_n^2 + p_\perp^2}\]对\(A(\mathbf{p})\)进行求导有:
\[\frac{\partial A}{\partial p_e} = 0\] \[\frac{\partial A}{\partial p_n} = \frac{1}{2} b \cdot \frac{p_n}{\sqrt{p_n^2 + p_\perp^2}}\] \[\frac{\partial A}{\partial p_\perp} = \frac{1}{2} b \cdot \frac{p_\perp}{\sqrt{p_n^2 + p_\perp^2}}\]如果我们进一步假设\(p_n=0\),则\(A(\mathbf{p})\)仅与\(p_\perp\)有关。此时可以把面积\(A(\mathbf{p})\)的梯度表示为:
\[\nabla A(\mathbf{p}) = \frac{1}{2} b \ \mathbf{e}_\perp\]data:image/s3,"s3://crabby-images/e73b8/e73b87a6c89afe88e2e6e3d5e6e6949c3cca20ad" alt=""
根据平面几何,我们可以把三角形底边的高向量\(\mathbf{h}\)使用三个顶点位置向量来表示:
\[\frac{b}{h} = \cot \alpha + \cot \beta\] \[\mathbf{h} = \mathbf{p} - \mathbf{p}_0 = \mathbf{p} - \frac{\mathbf{r} \cot \alpha + \mathbf{q} \cot \beta}{\cot \alpha + \cot \beta}\]data:image/s3,"s3://crabby-images/a9845/a9845cf630c9366c756fb7e5bb56904592871880" alt=""
把上面的公式结合起来可以得到使用三角形内几何量表示的面积梯度:
\[\begin{aligned} \nabla A(\mathbf{p}) &= \frac{1}{2} b \ \mathbf{e}_\perp = \frac{1}{2} \frac{b}{h} \mathbf{h} \\ &= \frac{1}{2} \bigg( (\mathbf{p} - \mathbf{r}) \cot \alpha + (\mathbf{p} - \mathbf{q}) \cot \beta \bigg) \end{aligned}\]data:image/s3,"s3://crabby-images/6e659/6e659c25f2b0b4b2e9be679cdeacca7847e81840" alt=""
在三角网格上我们把顶点相邻的所有三角形的面积梯度加起来就得到了曲面的面积梯度:
\[\nabla A(\mathbf{p}) = \frac{1}{2} \sum_j (\cot \alpha_j + \cot \beta_j) (\mathbf{p} - \mathbf{q}_j)\]data:image/s3,"s3://crabby-images/a973d/a973db0698dfcde866556385999999d72a7dd262" alt=""
因此上面推导的面积梯度即为mean curvature normal在顶点附近的积分。
data:image/s3,"s3://crabby-images/f0d59/f0d590c8d62c1c75fb5db00746aa426849fc5062" alt=""
data:image/s3,"s3://crabby-images/75502/755020fcecdedf02a12ee21cf0c3e1600a63e78b" alt=""
Alternative Structures
除了上面介绍的方法外我们还可以利用曲率的其它性质来推导离散曲率的表达式。
data:image/s3,"s3://crabby-images/32225/32225581c823bb8616d15adac2ef3105427ec341" alt=""
data:image/s3,"s3://crabby-images/3b92e/3b92e36ab63f3e96a4a19d66a8f8cf5edebeac60" alt=""
data:image/s3,"s3://crabby-images/b0992/b09927ece6d48007b11ebc0ccf89f3cede9d8290" alt=""
data:image/s3,"s3://crabby-images/6e847/6e847e1fa8a9e3d98573630079811c62bdc3df31" alt=""
data:image/s3,"s3://crabby-images/1aa1a/1aa1ae7abcb2bafe6aab77861735a0e93a241129" alt=""