Fast Simulation of Mass-Spring Systems in Rust 论文阅读

news2024/11/22 22:05:18

参考资料:

Fast Simulation of Mass-Spring Systems in Rust

论文阅读:Fast Simulation of Mass-Spring Systems

【论文精读】讲解刘天添2013年的fast simulation of mass spring system(Projective Dynamics最早的论文)

Projective Dynamics笔记(一)——Fast Mass Spring

文章目录

  • 概述
  • 流程概述:
  • 1.前置知识
      • 1.1 运动方程(牛顿第二定律)
      • 1.2 二阶导数的离散化
      • 1.3 代入运动方程
      • 1.4 物理意义
  • 2. 将隐式积分问题转化为一个优化问题
    • 2.1 要解的是隐式积分问题是:
    • 2.2 引入辅助变量d
    • 2.3 Block Coordinate Descent(块坐标下降法)
      • Global Step部分

概述

这篇论文通过引入弹簧方向的辅助变量,并采用块坐标下降法解决了传统隐式欧拉法中速度慢的问题,成功实现了弹簧质点系统的快速仿真。该方法特别适用于实时应用,并且在低迭代次数下也能得到较好的视觉效果。

流程概述:

1.前置知识

1.1 运动方程(牛顿第二定律)

在物理仿真中,系统的运动通常由二阶微分方程描述,例如: M d 2 q d t 2 = f ( q ) M \frac{d^2q}{dt^2} = f(q) Mdt2d2q=f(q)
其中:

  • ( M ) 是质量矩阵,表示系统中各质点的质量。
  • ( q(t) ) 是位置向量,表示质点的位置。
  • ( f(q) ) 是作用在质点上的力,通常是位移 ( q ) 的函数。

1.2 二阶导数的离散化

使用中心差分法,二阶导数 ( d 2 q d t 2 \frac{d^2q}{dt^2} dt2d2q ) 的离散形式为:
d 2 q d t 2 ≈ q n + 1 − 2 q n + q n − 1 h 2 \frac{d^2q}{dt^2} \approx \frac{q_{n+1} - 2q_n + q_{n-1}}{h^2} dt2d2qh2qn+12qn+qn1
其中:

  • ( q_n ) 是时间 ( t_n ) 时的位置。
  • ( q_{n+1} ) 是时间 ( t_{n+1} = t_n + h ) 时的位置。
  • ( q_{n-1} ) 是时间 ( t_{n-1} = t_n - h ) 时的位置。
  • ( h ) 是时间步长

1.3 代入运动方程

将二阶导数的离散化形式代入运动方程 ( M d 2 q d t 2 = f ( q ) M \frac{d^2q}{dt^2} = f(q) Mdt2d2q=f(q) ):
M q n + 1 − 2 q n + q n − 1 h 2 = f ( q n + 1 ) M \frac{q_{n+1} - 2q_n + q_{n-1}}{h^2} = f(q_{n+1}) Mh2qn+12qn+qn1=f(qn+1)
最后我们得到隐式欧拉法的公式:
M ( q n + 1 − 2 q n + q n − 1 ) = h 2 f ( q n + 1 ) M(q_{n+1} - 2q_n + q_{n-1}) = h^2 f(q_{n+1}) M(qn+12qn+qn1)=h2f(qn+1)
其中,( q n + 1 q_{n+1} qn+1 ) 是需要通过求解获得的未知位置,( f ( q n + 1 ) f(q_{n+1}) f(qn+1) ) 依赖于 ( q n + 1 q_{n+1} qn+1 ),因此这是一个隐式公式

1.4 物理意义

在这里插入图片描述

2. 将隐式积分问题转化为一个优化问题

2.1 要解的是隐式积分问题是:

M q n + 1 − 2 q n + q n − 1 h 2 = f ( q n + 1 ) M \frac{q_{n+1} - 2q_n + q_{n-1}}{h^2} = f(q_{n+1}) Mh2qn+12qn+qn1=f(qn+1)
其中:
n是时间迭代步
q是所有粒子的位置向量
M是粒子质量对角矩阵
h是时间步长
f是整个系统的保守力
q n + 1 q_{n+1} qn+1是未知状态量,设为x。 q n q_{n} qn q n − 1 q_{n-1} qn1是已知量,设为 y = 2 q n − q n − 1 y=2q_{n}-q_{n-1} y=2qnqn1
所以得到式子 M ( x − y ) = h 2 f ( x ) M(x-y)=h^2f(x) M(xy)=h2f(x)
求解这个方程,等效于求解下面这个方程的极小值:
(令g(x)求导为0得到上式)
g ( x ) = 1 2 ( x − y ) T M ( x − y ) + h 2 E ( x ) g(x) = \frac{1}{2}(x - y)^T M (x - y) + h^2 E(x) g(x)=21(xy)TM(xy)+h2E(x)

其中,( E ) 为系统的势能(因为 ( ∇ E = − f \nabla E = -f E=f ),因此 ( ∇ g = 0 \nabla g = 0 g=0 ) 等效于公式 (7))。

按照胡克定律,弹簧的弹性势能为:

E = 1 2 k ( ∥ p 1 − p 2 ∥ − r ) 2 E = \frac{1}{2} k ( \|p_1 - p_2\| - r )^2 E=21k(p1p2r)2

其中:

  • ( p 1 , p 2 p_1, p_2 p1,p2 ) 为两个粒子的位置,
  • ( r ) 为弹簧的静止长度(rest length)。

但如果直接采用这个形式,上面的 ( g(x) ) 极值问题就不太好解。为了将上式变形为一个方便求解的形式,作者引入了一个辅助变量 ( d ∈ R 3 d \in \mathbb{R}^3 dR3 )。

2.2 引入辅助变量d

公式如下:
假设d是一个未知的三位向量,那么:
( ∥ p 1 − p 2 ∥ − r ) 2 = min ⁡ ∥ d ∥ = r ∥ p 1 − p 2 − d ∥ 2 (\|p_1 - p_2\| - r)^2 = \min_{\|d\|=r} \|p_1 - p_2 - d\|^2 (p1p2r)2=d=rminp1p2d2

1. 左边公式的物理意义:

左边的公式 ( ( ∥ p 1 − p 2 ∥ − r ) 2 (\|p_1 - p_2\| - r)^2 (p1p2r)2 ) 是弹簧势能的表示形式,依据胡克定律,它表示弹簧当前长度 ( |p_1 - p_2| ) 与静止长度 ( r ) 之间的差的平方。这里 ( p 1 p_1 p1 ) 和 ( p 2 p_2 p2 ) 是弹簧两端质点的位置

2. 右边公式的几何解释:

右边的公式引入了一个辅助向量 ( d ),并对其施加约束 ( |d| = r )。这个向量表示固定长度为 ( r ) 的向量,但方向可以自由变化。优化问题为:
min ⁡ ∥ d ∥ = r ∥ p 1 − p 2 − d ∥ 2 \min_{\|d\|=r} \|p_1 - p_2 - d\|^2 d=rminp1p2d2
这个问题的意思是寻找一个向量 ( d ),使得 ( p 1 − p 2 p_1 - p_2 p1p2 ) 与 ( d ) 的差最小,即让 ( ∥ p 1 − p 2 − d ∥ \|p_1 - p_2 - d\| p1p2d ) 最小化

显然当 d = r p 1 − p 2 ∥ p 1 − p 2 ∥ 时取极小值 显然当d = r \frac{p_1 - p_2}{\|p_1 - p_2\|}时取极小值 显然当d=rp1p2p1p2时取极小值

重新定义弹簧的弹性势能E(x,d)

在这里插入图片描述

矩阵L和J的推导

在这里插入图片描述

第一行的式子为什么可以等于L和J,证明如下:
忽略 d i T d i d^T_{i}d_{i} diTdi是关于 d 的平方项,但这项对 x 的优化没有直接影响,因此我们暂时忽略它,只关注 x 和 d 之间的关系

在这里插入图片描述
S i T S_i^T SiT是一个选择矩阵,是一个单位向量(标准基),用于选择第 𝑖个弹簧的位移变量 d i d_{i} di

在这里, d = S i T d d = S_i^T d d=SiTd 可以理解为,向量 d d d 中的每个分量 d i d_i di 对应一个特定的弹簧的偏移量。通过 S i T d S_i^T d SiTd,我们提取了 d d d 中与第 i i i 个弹簧相关的那部分位移。

换句话说, S i T S_i^T SiT 确保我们从总的 d d d 向量中只选取第 i i i 个元素(因为 S i T S_i^T SiT 是一个标准基,其他位置上的元素都会被置为 0)。

因此,对于每个弹簧 i i i,我们有:

d i = S i T d d_i = S_i^T d di=SiTd

这表示 d i d_i di 是通过选择矩阵 S i T S_i^T SiT d d d 中提取出来的。
在这里插入图片描述

外力为什么放在 X T () X^T() XT()里面

外力 𝑓 e x t 𝑓_{ext} fext被视作对系统的额外作用力,所以在总的能量函数中,它会影响线性部分,即外力对位移 x 的作用是线性的。因此,外力项自然可以放入这个线性项中
乘以 h 2 ℎ^2 h2体现了外力在整个时间步长内的累积效应
力和加速度是直接相关的。加速度是位移 𝑥对时间 𝑡的二阶导数。而当我们离散化这个二阶导数时,时间步长 ℎ被平方了

2.3 Block Coordinate Descent(块坐标下降法)

在这里插入图片描述

Global Step部分

在这里插入图片描述

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

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

相关文章

新手做私域学会这三步,一周时间营收翻倍

在数字化营销的时代,私域流量的运营已经成为品牌和创业者提升营收的关键。如果你是一个私域营销的新手,那么这篇文章将是你的福音。我们将分享三个简单而有效的步骤,帮助你在短短一周内实现营收翻倍的目标。 第一步:明确人设——…

SpringBoot项目整合Knife4J

SpringBoot项目整合Knife4J 前言为什么要使用API文档什么是API文档 Knife4jKnife4j的进化史Swagger和Knife4J的关系 SpringBoot整合Knife4j版本适配实现步骤1.导入依赖2.编写配置类新建一个controller进行测试启动项目 Knife4j增强配置常用注解例子展示实体类注解Controller注解…

【大数据学习 | kafka】kafuka的基础架构

1. kafka是什么 Kafka是由LinkedIn开发的一个分布式的消息队列。它是一款开源的、轻量级的、分布式、可分区和具有复制备份的(Replicated)、基于ZooKeeper的协调管理的分布式流平台的功能强大的消息系统。与传统的消息系统相比,KafKa能够很好…

HarmonyOS 相对布局(RelativeContainer)

1. HarmonyOS 相对布局(RelativeContainer) 文档中心:https://developer.huawei.com/consumer/cn/doc/harmonyos-guides-V5/arkts-layout-development-relative-layout-V5   RelativeContainer为采用相对布局的容器,支持容器内部的子元素设…

海螺 2.27.1 |AI生成视频 AI音乐 语音通话

嗨!我是小海螺,你的AI智能伙伴,帮助你学习工作效率加倍!我无所不知,又像朋友陪你左右,遇到问题,就问我吧。我所使用的技术,是MiniMax公司自研的万亿参数MoE大模型。我们希望能与用户…

【SpringCloud】Seata微服务事务

Seata微服务事务 分布式事务问题:本地事务分布式事务演示分布式事务问题:示例1 分布式事务理论CAP定理一致性可用性分区容错矛盾 Base理论解决分布式事务的思路 初识SeataSeata的架构部署TC服务微服务集成Seata引入依赖配置TC地址 其他服务 动手实践XA模…

WRB Hidden Gap,WRB隐藏缺口,MetaTrader 免费公式!(指标教程)

WRB Hidden Gap MetaTrader 指标用于检测和标记宽范围的柱体(非常长的柱体)或宽范围的烛身(具有非常长实体的阴阳烛)。此指标可以识别WRB中的隐藏跳空,并区分显示已填补和未填补的隐藏跳空,方便用户一眼识别…

Zustand介绍与使用 React状态管理工具

文章目录 前言基本使用编写状态加方法在组件中使用异步方法操作 中间件简化状态获取优化性能 持久化保存 前言 在现代前端开发中,状态管理一直是一个关键的挑战。随着应用规模的扩大,组件间的状态共享变得愈加复杂。为了应对这一需求,开发者…

Java-图书管理系统

我的个人主页 欢迎来到我的Java图书管理系统,接下来让我们一同探索如何书写图书管理系统吧! 1管理端和用户端 2建立相关的三个包(book、operation、user) 3建立程序入口Main类 4程序运行 1.首先图书馆管理系统分为管理员端和…

使用Poste搭建内网邮件服务器

使用Poste搭建内网邮件服务器 Poste.io 也是一个流行的邮件服务器方案,它可以通过 Docker 容器轻松部署,非常适合搭建内部邮件服务器。 本文档将向您展示如何开始使用 Poste.io 邮件服务器。在 5 分钟内,您将拥有一个可发送和接收邮件的邮件…

Springboot 使用EasyExcel导出Excel文件

Springboot 使用EasyExcel导出Excel文件 Excel导出系列目录:引入依赖创建导出模板类创建图片转化器 逻辑处理controllerservice 导出效果遗留问题 Excel导出系列目录: 【Springboot 使用EasyExcel导出Excel文件】 【Springboot 使用POI导出Excel文件】 …

基于Python大数据的王者荣耀战队数据分析及可视化系统

作者:计算机学姐 开发技术:SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等,“文末源码”。 专栏推荐:前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码、微信小程序源码 精品专栏:…

es实现自动补全

目录 自动补全 拼音分词器 安装拼音分词器 第一步:下载zip包,并解压缩 第二步:去docker找到es-plugins数据卷挂载的位置,并进入这个目录 第三步:把拼音分词器的安装包拖到这个目录下 第四步:重启es 第…

使用freemarker实现在线展示文档功能开发,包括数据填充

首先,在这个独属于程序员节日的这一天,祝大家节日快乐【求职的能找到心仪的工作,已经工作的工资翻倍】。 ---------------------------------------------------------------回到正文-----------------------------------------------------…

大数据处理随堂测试

HDFS MapReduce HBase Spark

【Linux驱动开发】设备树节点驱动开发入门

【Linux驱动开发】设备树节点驱动开发入门 文章目录 设备树文件设备树文件驱动开发附录:嵌入式Linux驱动开发基本步骤开发环境驱动文件编译驱动安装驱动自动创建设备节点文件 驱动开发驱动设备号地址映射,虚拟内存和硬件内存地址字符驱动旧字符驱动新字…

Redis 集群 总结

前言 相关系列 《Redis & 目录》(持续更新)《Redis & 集群 & 源码》(学习过程/多有漏误/仅作参考/不再更新)《Redis & 集群 & 总结》(学习总结/最新最准/持续更新)《Redis & 集群…

Postman常见问题及解决方(全)

🍅 点击文末小卡片 ,免费获取软件测试全套资料,资料在手,涨薪更快 1、网络连接问题 如果Postman无法发送请求或接收响应,可以尝试以下操作: 检查网络连接是否正常,包括检查网络设置、代理设置…

接口测试(五)jmeter——get请求

一、get请求——短信验证码(示例仅供参考) 1. get请求:传参数据直接拼接在地址后面,jmeter不需要设置请求头content-type 注:短信验证码接口,返回结果中不会返回短信验证码,是存在数据库表中&a…

Pyramidal Flow使用指南:快手、北大、北邮,开源可免费商用视频生成模型,快速上手教程

什么是 Pyramidal Flow? Pyramidal Flow 是由快手科技、北京大学和北京邮电大学联合推出的开源视频生成模型,它是完全开源的,发布在 MIT 许可证下,允许商业使用、修改和再分发。该模型能够通过文本描述生成最高10秒、分辨率为128…