Shape Analysis课程笔记20-Correspondence Problems
这个系列是MIT 6.838: Shape Analysis的同步课程笔记。本课程会介绍几何方法在图形学、机器学习、计算机视觉、医疗图像以及建筑设计等相关领域的原理和应用。本节主要介绍曲面对应问题。
Surface Correspondence Problems
曲面对应(surface correspondence)是指寻找两个曲面的对应关系。以人脑MRI为例,我们知道大脑皮层的不同区域有着相应的功能,很多时候我们需要将两个大脑具有相同功能的区域进行匹配。从几何的角度来看,这样的任务本质是计算两个曲面的对应关系。
data:image/s3,"s3://crabby-images/d6981/d69813423acbb1a4baad3875bc1a42a34c55de22" alt=""
与曲面对应类似的一个常见任务是配准(registration)。二者的主要区别在于配准一般是计算同一物体不同表示之间的对应关系,它的输出一般是不同表示之间的刚性变换;而曲面对应则不仅仅考虑同一个物体的情况,实际上即使是不同类型的物体在很多时候也存在一定的对应关系。
data:image/s3,"s3://crabby-images/de115/de1150e4c053b2b6f251a1e4c897832b1072f46b" alt=""
Applications
曲面对应在各种实际工程中都有着大量的应用。在图形学中我们可能会希望把一个模型的纹理变换到另一个模型上,这样的任务需要就需要计算两个不同模型之间的对应关系,称为纹理迁移(texture transfer)。
data:image/s3,"s3://crabby-images/4d2cc/4d2ccc82bdd2bde573054f0dc3c9762e86672ac9" alt=""
类似地,网格的分割也可以考虑使用曲面对应来进行处理:我们可以先在一个相对简单的模型上进行精细的分割,然后利用曲面对应把分割结果映射到新的模型上。
data:image/s3,"s3://crabby-images/e7531/e7531b1294eb3d65737e17f01e04efabae67c54d" alt=""
计算网格的骨架也可以使用类似的方法。
data:image/s3,"s3://crabby-images/d0135/d0135bc6b1ca9e60debb1fa8c58117283a1bc57c" alt=""
基于曲面对应的思想,我们可以把人脸的不同表情对应到一个基准模型上,然后通过插值来实现表情的混合。
data:image/s3,"s3://crabby-images/13579/135792325f06e72f258320ef2ac8ae3e3516e31c" alt=""
当然曲面对应也可以用来进行形状分析。实际上很多形状分析算法都会使用曲面对应技术作为分析前的预处理,这样可以去除各种曲面扫描产生的误差。
data:image/s3,"s3://crabby-images/4bc3d/4bc3d893b956bb60fb3857297d5bbff110e24c5b" alt=""
data:image/s3,"s3://crabby-images/749f2/749f255a1c4dc3ce0e54d6ed2b6217ffb1fc450b" alt=""
Geometric Quality
从数学的角度来看,曲面对应的本质是计算两个(或多个)曲面之间的映射\(f\)。当然我们希望\(f\)比较易于计算,同时具有双射、低扭曲以及保持原有曲面几何特征等优良性质。
data:image/s3,"s3://crabby-images/67534/67534d7893cee1905062906c8bb52ad0d647aa53" alt=""
实际上低扭曲是一个相当高的要求,很多全局看上去正确的映射在局部可能会有过大的几何扭曲。
data:image/s3,"s3://crabby-images/b6e52/b6e5236056345379547651ddda3b80b39ef2c1c5" alt=""
在比较不同的映射时,一种常见做法是统计曲面不同位置映射后与ground truth之间的累计误差。不过需要注意的是几何扭曲大的映射有时反而会有更小的累计误差,因此在设计和比较算法时往往还需要在映射的误差和光滑性上进行权衡。
data:image/s3,"s3://crabby-images/16c1d/16c1d75217f834869201a9d710431a9d4134ec17" alt=""
data:image/s3,"s3://crabby-images/6f5a0/6f5a0114fcbc37cc968662939cb8c15420b6842b" alt=""
在一些更现代的工作中人们常常会使用共形扭曲来衡量映射的质量,其描述了映射保持曲面上角度的能力。
data:image/s3,"s3://crabby-images/34e1d/34e1dc9724293fbcf0376f83b300a54312faa818" alt=""
Strategies
接下来我们开始介绍曲面对应的一些常见策略。
data:image/s3,"s3://crabby-images/5f734/5f73454a326d1da9be64a9433c4ab1a495940364" alt=""
Co-Parameterization
Co-Parameterization是计算曲面对应的经典方法。它的思路是首先在不同的网格上选取相互对应的landmark,然后利用landmark之间的连接关系将网格划分为相互对应的patch,相互对应的patch具有相同的拓扑关系。
data:image/s3,"s3://crabby-images/ae012/ae0122590ac41ef58fe825a5caff0523d93f9e6c" alt=""
这样在对应的patch上就可以利用参数化这样的技术将它们映射到相同的参数域上,进而得到分片网格的对应关系。
data:image/s3,"s3://crabby-images/a4492/a44922c09872ec82dc4372fa2af0c61654c0d375" alt=""
data:image/s3,"s3://crabby-images/bb8e2/bb8e2fcf574704cb25394ca6e69f9077712e44ff" alt=""
data:image/s3,"s3://crabby-images/577a6/577a6db31360bae981aa6e727db7dbafd011f931" alt=""
Co-Parameterization的优势在于它比较容易实现,而且基于Tutte’s embedding可以保证计算得到的曲面对应函数\(f\)是一个双射;而其缺陷则在于它需要手动选取曲面上相互对应的landmark,而且往往具有比较大的几何扭曲。
data:image/s3,"s3://crabby-images/012bd/012bd4794751c8d181655abcdbd2ee7da1301d09" alt=""
近几年有一些针对传统Co-Parameterization方法的改进,通过自动选取landmark来减少几何扭曲。
data:image/s3,"s3://crabby-images/1e51a/1e51a0059324a0270c0917d0382b570d4f39e8cc" alt=""
而一些对于Tutte’s embedding的改进还可以让我们处理具有不同拓扑的网格和区域。
data:image/s3,"s3://crabby-images/4c998/4c998b93bf6b55215e075767761262720d29d8fd" alt=""
值得说明的是Co-Parameterization的思想不仅仅局限于图形学相关的应用中,在神经科学和脑科学中常用的FreeSurfer实际上也使用了类似的技术。
data:image/s3,"s3://crabby-images/bd5bb/bd5bb71561516d143e401ffb7626928747053b30" alt=""
另外需要注意的是Co-Parameterization的质量在很大程度上依赖于选择的参数化算法,除了Tutte’s embedding之外还可以考虑很多更现代的算法。
data:image/s3,"s3://crabby-images/25943/2594306a00813fc0713c5ed4cb58ba46cb0bf749" alt=""
这里我们简单介绍一些SLIM算法,它是最近几年比较有代表性的工作。首先来考虑平面三角形的变形,变形函数\(\phi_t\)可以表示为一个线性变换:
\[\phi_t (x) = J_t x + c\]其中\(c\)为三角形的平移,因此\(\phi_t\)的几何扭曲完全由Jacobian矩阵\(J_t\)控制。这样整个三角形网格上的扭曲可以描述为:
\[\sum_{t \in T} A_t \ \mathcal{D}(J_t)\]其中\(A_t\)为每个小三角形的面积,而\(\mathcal{D}(J_t)\)为扭曲的度量函数。
data:image/s3,"s3://crabby-images/1fca4/1fca4fece024c98b0c0f408b278ff4bf093d63ac" alt=""
这样整个参数化问题就可以转换为针对三角形Jacobian矩阵的优化问题,我们就可以利用各种优化器来进行求解。一些常用的扭曲度量函数可参考如下:
data:image/s3,"s3://crabby-images/b3323/b33235a7ac6539c460dce02a920524b7cf4f411e" alt=""
data:image/s3,"s3://crabby-images/1b85c/1b85c9edb4ca39d59dc4d4409dea6af28605ebc8" alt=""
Generalized MDS
在经典Co-Parameterization的基础上,一些近期的研究指出通过保持曲面上的一些长距关系可以得到更稳定的结果。
data:image/s3,"s3://crabby-images/c5bc2/c5bc28b0c7abe311073263ba5d2e3776fb49040b" alt=""
这里我们需要引入Gromov-Hausdorff距离(Gromov-Hausdorff distance)的概念,它描述了两个度量空间\(X\)和\(Y\)之间的距离。
data:image/s3,"s3://crabby-images/67903/67903f4af29d86ec331637ae451f67a67f24c39f" alt=""
Generalized MDS(GMDS)算法可以理解为在两个曲面上对Gromov-Hausdorff距离进行优化。
data:image/s3,"s3://crabby-images/ed8c0/ed8c0b577c2036cd5850eeab6041c242ac8a3928" alt=""
从更通用的形式来看,GMDS等价于求解quadratic assignment。不过遗憾的是直接求解quadratic assignment是NP-hard。
data:image/s3,"s3://crabby-images/62e3b/62e3bd8e632f7ab72b3ef49a8a109dbae269072f" alt=""
同时还需要注意在求解时可能会出现各种局部极值。
data:image/s3,"s3://crabby-images/4064c/4064c268433410e7f9fddefa105bc45fc96a3c7d" alt=""
总之,GMDS相关方法的难点在于我们很难进行求解。很多情况下需要使用各种技巧才能进行处理。
data:image/s3,"s3://crabby-images/868b4/868b4a1e510678bd408c08269a1c51a2c9c07959" alt=""
data:image/s3,"s3://crabby-images/e10db/e10dbd4f11416b6c81d727cf42a3d31576328cda" alt=""
data:image/s3,"s3://crabby-images/fb76f/fb76f5cd87ea375a5d823ab93e67a38617200bc3" alt=""
data:image/s3,"s3://crabby-images/01b2b/01b2bbd0bb0e70bebf7c9ae006f0c5e7aa0261c9" alt=""
data:image/s3,"s3://crabby-images/6540c/6540c5504950378cd2a97cc4d344325b24e022b6" alt=""
一些近期的研究还指出GMDS可以结合最优传输理论进行理解。
data:image/s3,"s3://crabby-images/19c55/19c556311d5f5d563bae61a9b1ec7e6a8a9ddaaf" alt=""
data:image/s3,"s3://crabby-images/642bc/642bc21045b0fa128eb0ff5e30c4613540327785" alt=""
data:image/s3,"s3://crabby-images/34e28/34e28df33ea2d82566c79886d7b1f6a6da37ddcc" alt=""
除此之外GMDS也可以结合convex relaxation这样的技巧来进行加速。
data:image/s3,"s3://crabby-images/d9017/d9017a252b2d114ba662d7ce10877c4d5c9adbc4" alt=""
Heat Kernel Map
如果两个曲面之间仅相差一个等距变换,我们则可以使用heat kernel signature来计算曲面对应。此时只需要分别计算曲面上每个顶点的descriptor然后进行匹配即可。
data:image/s3,"s3://crabby-images/4a296/4a296546dfd9fe4ec02e35820fce5c42564706f8" alt=""
当然,如果两个曲面之间偏离了等距变换这种方法可能无法得到正确的结果。
data:image/s3,"s3://crabby-images/d2f9d/d2f9dff181311a64e14559405961603fcb4b34d7" alt=""
Möbius Voting
在很多情况下曲面之间等距变换的约束可能过强,因此一种常见的策略是将等距变换放松为共形映射(conformal mapping)。和等距变换相比,共形映射仅能保持角度不变而不再保证距离不变。
data:image/s3,"s3://crabby-images/cf5e0/cf5e06bf9ded6bd1f6b5a5e0cfd5e3b2eccc478c" alt=""
使用共形映射计算曲面对应的基本思路是首先将两个曲面分别共形参数化到(复)平面上,然后再寻找这两个(复)平面之间的共形映射。
data:image/s3,"s3://crabby-images/76d2b/76d2b4225284eb7092c53a6d1c202c7690c33141" alt=""
data:image/s3,"s3://crabby-images/ad7f3/ad7f3d634779be5a9d314fba2064726aadc4b389" alt=""
而平面之间的共形映射可以使用Möbius变换(Möbius transform)进行描述。
data:image/s3,"s3://crabby-images/93df6/93df63b4470dc6046ab10e499827f7d56fb6db92" alt=""
把这些步骤组合到一起就得到了Möbius voting算法:它会在(复)平面上不断选取triplet来计算Möbius变换,而其中具有最小几何扭曲的那个构成了所需的曲面对应。
data:image/s3,"s3://crabby-images/60a55/60a55b1b5022f740c38a88a0bc4b68a1c0114a83" alt=""
data:image/s3,"s3://crabby-images/87467/87467ef197917e3be9d72e672086c844d31206d2" alt=""
显然Möbius voting算法非常高效,但它无法保证一定能找到最优的对应,而且仅适用于亏格为0的曲面。
data:image/s3,"s3://crabby-images/51e3b/51e3b4114a56a2b42183f67d79c7b712d88d9965" alt=""
Blended Intrinsic Map
在Möbius voting的基础上人们还提出了blended intrinsic map的技术,它会利用不同的triplet来计算曲面对应,然后把它们组合起来作为最终的对应。
data:image/s3,"s3://crabby-images/f8731/f873156619df572372a00c74ec353058ded4da82" alt=""
data:image/s3,"s3://crabby-images/1a2f6/1a2f6ccffd696ea69c67a94d4e3abe3cef6f0fab" alt=""
data:image/s3,"s3://crabby-images/9e96b/9e96bb44f75cb60ab92f9880ea2f155294bf7049" alt=""
data:image/s3,"s3://crabby-images/a7591/a7591ce2b7fbd0a6ffadc45e668ba851ffeeae7a" alt=""
data:image/s3,"s3://crabby-images/ad127/ad127f6e98663a32e134c6bcfbe6baff9a99c7b6" alt=""
data:image/s3,"s3://crabby-images/0b8f3/0b8f3b312a2b5835cd06b143c50d422536539053" alt=""
data:image/s3,"s3://crabby-images/f7631/f76316f0e7028ff0588850b66e0ac6e73b71e87c" alt=""
data:image/s3,"s3://crabby-images/fbffc/fbffcf2cf043e23f3b6695a9a40a7debf1437227" alt=""
Functional Maps
data:image/s3,"s3://crabby-images/9f4d4/9f4d4bd8eb4856d0462f60e51fb9264b3b39fa5d" alt=""
data:image/s3,"s3://crabby-images/8bdba/8bdba00fc011e77dd275d73e40b640a41c8ab6c2" alt=""
data:image/s3,"s3://crabby-images/2ad75/2ad75393439e98045fc3eb518690b7d3dee44006" alt=""
data:image/s3,"s3://crabby-images/6b966/6b9661ed5984c743cc5943d7dc068f1fdf04136d" alt=""
data:image/s3,"s3://crabby-images/a1542/a1542e6b141e849874a4723a9b3bd94865a51462" alt=""
data:image/s3,"s3://crabby-images/835f2/835f26e110a41c4abb187fb1c221b380c31feff1" alt=""
data:image/s3,"s3://crabby-images/bc225/bc2252b13636c4ceba92be11f29716105e2d325b" alt=""
data:image/s3,"s3://crabby-images/f286d/f286deb1aef782621cfac208fe1a2d0f64f00461" alt=""
data:image/s3,"s3://crabby-images/4df0c/4df0c54c47e86a9ffcea6e8054a0fdf874283104" alt=""
data:image/s3,"s3://crabby-images/402ed/402ed731ef1ca218c7f42c6db8a72d1826de1ac6" alt=""
data:image/s3,"s3://crabby-images/16fb5/16fb5796cd2d07b0187c983cedd127b5f630c7ff" alt=""
data:image/s3,"s3://crabby-images/88c1a/88c1adfd814a8b3aed07f7afc2852022e42eaf69" alt=""
data:image/s3,"s3://crabby-images/ffdfb/ffdfb28810e9f86b79b96c0a74d19d4c6849a6c8" alt=""
data:image/s3,"s3://crabby-images/71c0d/71c0d55043f48778a5c05c837234bdcb5adc51f6" alt=""
data:image/s3,"s3://crabby-images/17f20/17f20f54e06bc210afc08f7eb8bd384aacfd3fc7" alt=""
data:image/s3,"s3://crabby-images/8b1cc/8b1cc3c690526d15d7bfb3b3412308fbe8ec3600" alt=""
data:image/s3,"s3://crabby-images/daf26/daf26534a99f1563f15a1faa4c56d2a2ff16e3f4" alt=""
data:image/s3,"s3://crabby-images/c6cf9/c6cf98562da9f49255ce300be9f05f718fb58b8f" alt=""
Reversible Harmonic Maps
本节课的extra content介绍了reversible harmonic maps这种技术。reversible harmonic maps可以用来处理dense correspondence的问题,此时我们已知两个曲面上几对landmark之间的对应关系,而目标是计算网格上其它顶点之间的对应关系。
data:image/s3,"s3://crabby-images/574d5/574d53289e3fad265266b500fc9db3191868ff6f" alt=""
High-Level Overview
reversible harmonic maps首先会根据landmark将网格划分为若干个cell,每个cell对应一个landmark。
data:image/s3,"s3://crabby-images/94467/94467c3c48d017ef26af6331849be43a17f723ae" alt=""
而算法的目标则是通过最小化能量函数来获得一个尽可能光滑的映射。
data:image/s3,"s3://crabby-images/145ef/145efe9f1d88b8af1dd047278eaab476dc736b60" alt=""
当我们使用Dirichlet能量作为目标函数时,最小化Dirichlet能量得到的映射称为调和映射(harmonic)。
data:image/s3,"s3://crabby-images/15506/1550671d05af1b129127f7276c4679fcdd1519c3" alt=""
而离散网格上的Dirichlet能量则可以通过测地距离来进行计算。
data:image/s3,"s3://crabby-images/2a857/2a857ed72bf3a60b78e0cd17687d95d084bd7213" alt=""
Precise Maps
在表示\(M_1\)上顶点映射后的坐标时还可以结合重心坐标,这种表示方法在论文中称为precise map。
data:image/s3,"s3://crabby-images/2b5f1/2b5f15961f07bb0799bb80a0a68c7c4911a467a8" alt=""
data:image/s3,"s3://crabby-images/c7a17/c7a173905328bb3998e271786a68d7bccd9fb804" alt=""
Discretization
而为了计算测地距离我们可以使用MDS中介绍过的技巧,通过高维空间中的欧式距离来进行近似。
data:image/s3,"s3://crabby-images/c3920/c3920d438550588dd6747a4a62bd301c14ed856d" alt=""
data:image/s3,"s3://crabby-images/c380d/c380d66e4ebad04cb755fc4bb59840409572c14a" alt=""
Optimization
在优化Dirichlet能量时还需要注意避免出现退化的情况。如果我们不加入任何限制,最小化Dirichlet能量的映射会把网格上的所有顶点映射到同一点上。
data:image/s3,"s3://crabby-images/b11d4/b11d47bbe2e5c884a4e1574c850d549e7dd0ddd2" alt=""
因此我们需要引入reversibility的概念来避免退化。
data:image/s3,"s3://crabby-images/92688/926887c0a0010484e21bd83e4b7ac82ea3584dfa" alt=""
data:image/s3,"s3://crabby-images/e5a0a/e5a0a78060d5c2cfde39dbee31acc8c99657d51f" alt=""
data:image/s3,"s3://crabby-images/61be5/61be57980b0e1c84fa6b8919cd446e58f7872033" alt=""
这样总体能量可以表示为Dirichlet能量与reversibility的加权和。
data:image/s3,"s3://crabby-images/af0ab/af0abc0b47cba042267261577ca1bc9b0997d9b3" alt=""
而在进行优化时还需要注意precise map要满足相应的非负和归一化条件。
data:image/s3,"s3://crabby-images/a06ff/a06ff364ae9ee5acce890e20a428de62166cd743" alt=""
data:image/s3,"s3://crabby-images/32852/3285276c49b93220f8797ffd73f557a3e268c2c7" alt=""
data:image/s3,"s3://crabby-images/8ccff/8ccfffd036e88c08fa1d8ff7bef8b41720802e25" alt=""
data:image/s3,"s3://crabby-images/fb148/fb148f5820b6613fa596a21eec0c30d5de3f5612" alt=""
data:image/s3,"s3://crabby-images/66464/664649135337ca8779a74920349d460ce02f44b7" alt=""
data:image/s3,"s3://crabby-images/c2b0b/c2b0b4fb49b839c694fdbb509f5c1802cf096a88" alt=""
data:image/s3,"s3://crabby-images/f2826/f28269ce9e26faca92a149fe2493380720f6bb43" alt=""
data:image/s3,"s3://crabby-images/36a1a/36a1a6ba2f56393907a1805eb016789dcabd986c" alt=""
data:image/s3,"s3://crabby-images/6873e/6873e61642a1eb1e2ad8c1f48b43108d25eb3705" alt=""
Results
data:image/s3,"s3://crabby-images/ac938/ac93855a46e23f2f6f923a073b3024ff6c8b12ca" alt=""
data:image/s3,"s3://crabby-images/2042f/2042fc7b0d6ee60d1bddfe14991be53f5e3ae093" alt=""