余切拉普拉斯算子推导 cotangent Laplace-Beltrami operator

news2024/10/5 10:39:37

欢迎关注更多精彩
关注我,学习常用算法与数据结构,一题多解,降维打击。

参考自polygon mesh proccessing这本书

基本思路及原理

余切拉普拉斯算子是一种考虑了网格底层几何联系的一种算子,在网格平滑,参数化等算法中经常被用到。它是受到了有限元思绪启发推导出来的。
用到有限元中的散度定理。
目标是对三角平面分片线性函数的梯度的散度进行面积积分。
散度定理如下,对散度的面积分,可以转化为梯度对边界的线积分。
∫ A i d i v    F ( u ) d ⁡ A = ∫ ∂ A i F ( u ) ⋅ n ( u ) d ⁡ s \int_{A_i}div\;F(u)\operatorname dA = \int_{\partial A_i}F(u) \cdot n(u) \operatorname ds AidivF(u)dA=AiF(u)n(u)ds

上述式子把对 A i 面积的积分和对 A i 边界( ∂ A i )的积分联系起来。 其中 n 代表与三角形共面并垂直于边界向外的单位向量。 上述式子把对A_i面积的积分和对A_i边界(\partial A_i)的积分联系起来。\\其中 \boldsymbol n 代表与三角形共面并垂直于边界向外的单位向量。 上述式子把对Ai面积的积分和对Ai边界(Ai)的积分联系起来。其中n代表与三角形共面并垂直于边界向外的单位向量。

拉普拉斯积分推导

在这里插入图片描述
将上述定理应用于拉普拉斯,可以得到下述公式

∫ A i Δ f ( u ) d ⁡ A = ∫ A i d i v ∇ f ( u ) d ⁡ A = ∫ ∂ A i ∇ f ( u ) ⋅ n ( u ) d ⁡ s \int_{A_i}{\Delta f(\boldsymbol u) \operatorname d A} = \int_{A_i}{div \nabla f(\boldsymbol u) \operatorname dA} =\int_{\partial A_i}{\nabla f(\boldsymbol u) \cdot \boldsymbol {n(u)} \operatorname d s} AiΔf(u)dA=Aidivf(u)dA=Aif(u)n(u)ds

我们可以对每个三角内的区域进行积分,如上图的右图,对于单个三角形,积分如下,三角形的梯度是常量可以提出来,a和b是中点。

∫ ∂ A i ∩ T ∇ f ( u ) ⋅ n ( u ) d ⁡ s = ∇ f ( u ) ⋅ ∫ ∂ A i ∩ T n ( u ) d ⁡ s = ∇ f ( u ) ⋅ ( a − b ) ⊥ = 1 2 ∇ f ( u ) ⋅ ( x j − x k ) ⊥ \int_{\partial A_i \cap T}{\nabla f(\boldsymbol u) \cdot \boldsymbol {n(u)} \operatorname d s} = \nabla f(\boldsymbol u) \cdot \int_{\partial A_i \cap T}{\boldsymbol {n(u)} \operatorname d s}= \nabla f(\boldsymbol u) \cdot (\boldsymbol a-\boldsymbol b)^\perp\\ =\frac 1 2 \nabla f(\boldsymbol u) \cdot (\boldsymbol {x_j}-\boldsymbol {x_k})^\perp AiTf(u)n(u)ds=f(u)AiTn(u)dsf(u)(ab)=21f(u)(xjxk)

下面解释一下上式中(a-b)怎么来的。

请添加图片描述
我们先把线的法向转90度与中间的小三角形平齐。
对线的积分就是乘上线的长度,所以旋转以后的分积就是小三角形三条边形成的向量。
原来积分的结果应该是
(a-c)+(c-b)

由于(a-c)+(c-b)+(b-a)=0
所以(a-b) = (a-c)+(c-b)

转化成余切形式

三角形的梯度是一个常量,代入上式,得到

∫ ∂ A i ∩ T ∇ f ( u ) ⋅ n ( u ) d ⁡ s = ( f j − f i ) ( x i − x k ) ⊥ ⋅ ( x j − x k ) ⊥ 4 A T + ( f k − f i ) ( x j − x i ) ⊥ ⋅ ( x j − x k ) ⊥ 4 A T \int_{\partial A_i \cap T}{\nabla f(\boldsymbol u) \cdot \boldsymbol {n(u)} \operatorname d s} = (f_j-f_i)\frac {(x_i-x_k)^\perp \cdot (x_j-x_k)^\perp}{4A_T} + (f_k-f_i)\frac {(x_j-x_i)^\perp \cdot (x_j-x_k)^\perp}{4A_T} AiTf(u)n(u)ds=(fjfi)4AT(xixk)(xjxk)+(fkfi)4AT(xjxi)(xjxk)

向量的点乘和叉乘可以转化成余弦和正弦。

γ j , γ k 表示 v j , v k 点上对应的角 \gamma_j,\gamma_k表示 v_j, v_k 点上对应的角 γj,γk表示vj,vk点上对应的角

面积
A T = 1 2 s i n γ j ∥ x j − x i ∥ ∥ x j − x k ∥ = 1 2 s i n γ k ∥ x i − x k ∥ ∥ x j − x k ∥ A_T=\frac {1} {2} sin \gamma_j\left\|x_j-x_i\right\|\left\|x_j-x_k\right\|=\frac {1} {2} sin \gamma_k\left\|x_i-x_k\right\|\left\|x_j-x_k\right\| AT=21sinγjxjxixjxk=21sinγkxixkxjxk

点乘
c o s γ j = ( x j − x i ) ⋅ ( x j − x k ) ∥ x j − x i ∥ ∥ x j − x k ∥ cos \gamma_j = \frac {(x_j-x_i)\cdot(x_j-x_k)}{\left\|x_j-x_i\right\|\left\|x_j-x_k\right\|} cosγj=xjxixjxk(xjxi)(xjxk)

c o s γ k = ( x i − x k ) ⋅ ( x j − x k ) ∥ x i − x k ∥ ∥ x j − x k ∥ cos \gamma_k = \frac {(x_i-x_k)\cdot(x_j-x_k)}{\left\|x_i-x_k\right\|\left\|x_j-x_k\right\|} cosγk=xixkxjxk(xixk)(xjxk)

将上面公式代入式子可得到

∫ ∂ A i ∩ T ∇ f ( u ) ⋅ n ( u ) d ⁡ s = 1 2 ( c o t γ k ( f j − f i ) + c o t γ j ( f k − f i ) ) \int_{\partial A_i \cap T}{\nabla f(\boldsymbol u) \cdot \boldsymbol {n(u)} \operatorname d s} = \frac 1 2 (cot \gamma_k(f_j-f_i)+cot \gamma_j(f_k-f_i)) AiTf(u)n(u)ds=21(cotγk(fjfi)+cotγj(fkfi))

上面公式是对一个三角形内区域的积分。
把所有三角形各分加起来,可以发现每条边都对应两个角(看最上面那张图左边),整体公式如下。

∫ A i Δ f ( u ) d ⁡ A = 1 2 [ ∑ v j ∈ N ( v i ) ( c o t α i , j + c o t β i , j ) ( f j − f i ) ] \int_{A_i}{\Delta f(\boldsymbol u) \operatorname d A} = \frac 1 2 \left [\displaystyle \sum_{v_j\in N(v_i)}(cot \alpha_{i,j}+cot \beta_{i,j})(f_j-f_i)\right ] AiΔf(u)dA=21 vjN(vi)(cotαi,j+cotβi,j)(fjfi)

得到点的拉普拉斯公式如下

Δ f ( v i ) = 1 2 A i [ ∑ v j ∈ N ( v i ) ( c o t α i , j + c o t β i , j ) ( f j − f i ) ] \Delta f(v_i) = \frac {1} {2A_i} \left [\displaystyle \sum_{v_j\in N(v_i)}(cot \alpha_{i,j}+cot \beta_{i,j})(f_j-f_i)\right ] Δf(vi)=2Ai1 vjN(vi)(cotαi,j+cotβi,j)(fjfi)


本人码农,希望通过自己的分享,让大家更容易学懂计算机知识。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/796419.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

no instance(s) of type variable(s) R exist so that void conforms to R 解决方法

一、问题描述 使用函数式编程stream().map()的时候报错: no instance(s) of type variable(s) R exist so that void conforms to R 二、报错原因 map()函数需要有一个返回值,但是setter方法返回值为void,即setChildren()返回值为void. 三、解决方法 …

SpringBoot前后端分离项目中实现将图片上传至Linux服务器(极简)

FileController /*** 文件上传至服务器 */ ApiOperation("文件上传") PostMapping("/upload") public R upload(MultipartFile file){String uploadUrl fileService.upload(file);return R.ok().message("文件上传成功").data("url",…

一遍看懂面试算法——二叉树

目录 二叉树的种类 满二叉树 完全二叉树 二叉搜索树 平衡二叉搜索树 二叉树的存储方式 二叉树的遍历方式 二叉树的递归遍历 二叉树的迭代遍历 前序遍历(迭代法) 中序遍历(迭代法) 后序遍历(迭代法&#xff…

Python-如何使用正则表达式

如何利用Python使用正则表达式 目录 正则表达式常用匹配规则 ​编辑re库的使用 match()方法: search()方法: findall()方法 : sub()方法: compile()方法; 通用匹配 贪婪与非贪婪匹配 贪婪匹配 非贪婪匹配 修饰符 转义匹配 正则表达式是处理字符的强大…

高电压放大器ATA-2021B技术指标

随着ATA-2021H高压放大器的升级改版,新品ATA-2021B高电压放大器走进了更多工程师、研究人员的视野。相比于升级之前,ATA-2021B高压放大器拥有了更多更好地优势,可以更好地的帮助研究人员高效完成测试项目。今天Aigtek小编就带大家了解一下关于…

liunx时间慢几分钟,定时更新系统时间

#!/bin/sh hwclock --hctosys echo "执行成功" 定时5分钟执行一次

minitab学习系列(2)--DOE逐步方法选择

系列文章目录 文章目录 系列文章目录前言一、DOE>因子>分析因子设计>逐步二、DOE>因子>分析因子设计>逐步>层次结构总结 前言 一、DOE>因子>分析因子设计>逐步 逐步删除和向模型中添加项以确定有用的项的子集。Minitab提供了三个常用过程&…

油画欣赏|《沧海的线条》在群山之间

《沧海的线条》80x65cm陈可之•2006年绘油画《沧海的线条》,通过绘画艺术的手法,描绘出三峡群山之间那一层层波浪般的纹理,展现出天地间岁月的古老沧桑变迁。此作品是陈可之先生百余幅三峡系列作品之一。夜,群山高大挺立。没有植被…

[SSM]Spring中的JdbcTemplate

目录 十三、JdbcTemplate 13.1环境准备 13.2新增 13.3修改 13.4删除 13.5查询 13.6查询一个值 13.7批量添加 13.8批量修改 13.9批量删除 13.10使用回调函数 13.11使用德鲁伊连接池 十三、JdbcTemplate JdbcTemplate是Spring提供的一个JDBC模板类,是对JDBC…

el-tree数据渲染超出省略

el-tree数据渲染超出省略 问题 <el-tree:data"deptOptions":props"defaultProps":expand-on-click-node"false":filter-node-method"filterNode"ref"tree"default-expand-allhighlight-currentnode-click"handleNo…

来自随身WIFI不限流量的暴击,今天你被割韭菜了吗?

大家好&#xff0c;前几天很多小伙伴私信葫芦妹&#xff0c;反馈买了个无限流量随身WIFI&#xff0c;一开始挺好用的&#xff0c;怎么用着用着不行了呢&#xff1f;必须让我给普及下。那么既然这些小伙伴需求这么强烈&#xff0c;那么今天葫芦妹得赶紧来教你如何辨别随身WIFI的…

【100天精通python】Day17:常见异常类型与解决,异常处理语句

目录 一 python 的常见异常类型与解决 二 常用的异常处理语句 1 try...except语句 2 try...except...else语句 3 try...except...finally语句 4 使用raise语句抛出异常 5 自定义异常类型 6 异常链处理 在 Python中&#xff0c;异常是在程序运行时发生的错误或意外情…

Spring Boot实践二 --Web开发

一、模板引擎简介 在之前的示例中&#xff0c;我们通过RestController来处理请求&#xff1a; package com.example.demospringboot.web;import org.springframework.web.bind.annotation.RestController; import org.springframework.web.bind.annotation.RequestMapping;Re…

1.Web API基本认知

变量声明 const优先&#xff0c;尽量使用const ●const声明的值不能更改&#xff0c;而且const声明变量的时候需要里面进行初始化 ●简单数据类型 用const声明后不能修改值 ●但是对于 引用数据类型&#xff0c;const声明的变量&#xff0c;里面存的不是值&#xff0c;是地址&a…

spring-authorization-server (1.1.1)自定义认证

前言 注意&#xff1a;我本地没有生成公钥和私钥&#xff0c;所以每次启动项目jwkSource都会重新生成&#xff0c;导致之前认证的token都会失效&#xff0c;具体如何生成私钥和公钥以及怎么配置到授权服务器中&#xff0c;网上有很多方法自行实现即可 之前有个项目用的0.0.3的…

ATA-2021B高压放大器经典应用合集(内附技术指标)

多年来Aigtek安泰电子一直潜心于电子测试仪器的研发&#xff0c;已拥有完善的功率放大器产品线&#xff0c;并针对超声声学、无损检测、电磁驱动、生物医疗、微流控、材料测试等主流各行业领域测试建立的了专属测试方案&#xff0c;在国内功率放大器行业及市场中获得认可&#…

【智能可视化---01】揭示Python AI中Matplotlib的魅力,提升数据洞察力!探索AI 中的Matplotlib,这一篇就够了!

Success keeps eluding me yet my passion abides. 🎯作者主页: 追光者♂🔥 🌸个人简介: 💖[1] 计算机专业硕士研究生💖 🌟[2] 2022年度博客之星人工智能领域TOP4🌟 🏅[3] 阿里云社区特邀专家博主🏅 🏆[4] CSDN-人工智能领域优质创作者…

团队运营能力不足?「企业学院」3大板块全面提升运营技能

『矩阵通』本期上线「企业学院」功能&#xff0c;内容包含新媒体培训课程、行业动态资讯及新媒体营销、矩阵运营的干货指南等&#xff0c;帮助企业提高团队运营能力&#xff0c;对此功能感兴趣的客户可前往矩阵通官网&#xff08;matrix.newrank.cn&#xff09;体验。 在当今数…

太绝了!医疗行业管理,原来可以这么简单!

在现代医疗领域&#xff0c;科技的不断进步和创新为医疗设备的发展带来了前所未有的突破和提升。然而&#xff0c;这些先进的医疗设备往往对其运行环境的要求非常严格&#xff0c;尤其是温度和湿度等参数的稳定性。 因此&#xff0c;为了确保医疗设备的高效、可靠运行&#xff…

【学会动态规划】删除并获得点数(13)

目录 动态规划怎么学&#xff1f; 1. 题目解析 2. 算法原理 1. 状态表示 2. 状态转移方程 3. 初始化 4. 填表顺序 5. 返回值 3. 代码编写 写在最后&#xff1a; 动态规划怎么学&#xff1f; 学习一个算法没有捷径&#xff0c;更何况是学习动态规划&#xff0c; 跟我…