【GAMES101】Lecture 22 物理模拟与仿真

目录

单粒子模拟

显式欧拉方法

改进

中点法/修正的欧拉方法

自适应步长

隐式欧拉方法

非物理改变位置(Position-Based / Verlet Integration)

刚体模拟

流体模拟


单粒子模拟

先来研究粒子的运动,假设有一个速度矢量场,对于确定的位置和时间可以确定粒子的速度

就会有一个计算粒子随时间的位置的一阶常微分方程Ordinary Differential Equation (ODE),一阶表示只有一阶的导数,常表示没有偏导

显式欧拉方法

显式的欧拉方法或者说是前向的欧拉方法就是用上一时刻t的位置加上上一时刻的速度乘以其间的时间间隔Δt来计算当前的位置,同样的方法计算出当前的速度

这个欧拉方法的误差和时间间隔Δt有关,这个间隔越小误差越小,间隔越大误差就越大,并且这个误差会因为积累而变得越来越大

减小Δt可以减小显式欧拉方法的误差,但是不能改变它的不稳定性,归根结底是因为这个步长无论取的多小始终是无法赶上速度场的变化,并且一旦出现了偏差就会继续累计

改进

中点法/修正的欧拉方法

我先算Δt/2时刻的位置,然后取这个中点位置的速度来计算下一时刻的位置

也就是取这个步长时间内的平均速度来计算下一时刻的位置

自适应步长

哎这个就很简单了,就是我先用Δt算一次结果,再用Δt/2算一次结果,如果两次结果差别不大,那我就停下来,这个结果就算出来了,否则的话我就以这个Δt/2的结果继续比较计算Δt/4的结果,这样继续算下去

隐式欧拉方法

我们之前显式的欧拉方法是用上一时刻的速度和加速度来计算当前时刻,那么用下一时刻的速度和加速度来计算当前时刻的就叫作隐式的欧拉方法或者说是后向的欧拉方法

我们把这个每个步长产生的误差叫做局部误差,总体累积的误差叫做全局误差,我们不关心数据的大小,关心这个误差的阶数,像这个隐式的欧拉方法它的局部误差的阶就是二次的,全局误差的阶是一次的,也就是说,当步长减少一半的时候,全局误差也会减少一半,也就是阶数越高误差下降的越快

有一类方法,叫做龙格库塔(Runge-Kutta Families),非常适合用来解这个常微分方程,并且它有一个误差的控制是四阶的方法

非物理改变位置(Position-Based / Verlet Integration)

这个实现很简单,什么呢?就是我直接去改变这个位置来满足某种约束,比如弹簧,当弹簧拉伸到某种程度立刻调整弹簧两个端点回到初始位置

刚体模拟

所谓刚体就是说它不会发生形变,也就是这个刚体内部的所有粒子的运动都是一样,那么就可以把它当成一颗粒子对待,但是会考虑更多的属性,像位置、旋转的角度、速度和角速度,以及它们对时间的导数

流体模拟

这里是Position-Based的一个简单应用,比如模拟水,我假设水是由很多刚体小球组成的并且这个水不可压缩,那也就是说水的密度应该是到处一样的,也就是水的某个地方里的刚体小球是一样的,一旦密度发生变化,就通过改变小球的位置使某处的小球数量恢复,也就是需要知道某处密度相对于小球位置的梯度通过梯度下降法来实现

这里有两种方法或者说是两种视角来模拟这种大量的物质

一个是质点法,也叫拉格朗日方法或者拉格朗日视角,就是对于每个个体进行模拟

还有一个是网格法,也叫欧拉方法或者是欧拉视角,也就是把空间分成很多网格,对于每个网格去研究它里面的东西随时间会发生什么变化

这两个方法也可以结合使用,叫做物质点方法或者材质点方法,Material Point Method (MPM),怎么做呢?我先考虑每个粒子的属性,然后在网格里面考虑粒子之间的整体作用并记录在网格里面,再对于网格里面的粒子去更新它们的状态

完结撒花,用了这个寒假学了games101课程并一直坚持把这个笔记做完,我一开始是先学这个OpenGL,发现确实很多概念不是很懂,然后来学games101,然后就非常的通透,目前games101作业还在做,估计这个寒假可以完成,再做几个小项目,希望能冲上游戏开发的岗位,唉大三了,希望能够顺利找到理想的暑期实习

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

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

相关文章

Java:字符集、IO流 --黑马笔记

一、字符集 1.1 字符集的来历 我们知道计算机是美国人发明的,由于计算机能够处理的数据只能是0和1组成的二进制数据,为了让计算机能够处理字符,于是美国人就把他们会用到的每一个字符进行了编码(所谓编码,就是为一个…

(已解决)将overleaf上的文章paper上传到arxiv上遇到的问题。

文章目录 前言初级问题后续问题 前言 首先说一点,将paper的pdf文件直接上传arxiv是不行的,arxiv要求我们要上传源文件,所以才这么麻烦。 初级问题 首先上传文件之后有可能会在下面这个界面出现问题,这里一般都比较常见的问题&a…

Latex排版遇到的常见问题及解决方法

这里写目录标题 1. 图片/ PDF 裁剪1.1 PPT 画图转PDF1.2 PPT裁剪 2. 表格内的文本换行问题2.1 表格跨行显示2.2 表格内文本换行,使用 ‘makecell’ 包 换行2.2 表格内文本添加 圆点 1. 图片/ PDF 裁剪 1.1 PPT 画图转PDF 1.2 PPT裁剪 将输出的PDF文件裁剪成合适尺…

最新酒桌小游戏喝酒小程序源码,带流量主,附带搭建教程

喝酒神器,增加了广告位,根据文档直接替换即可,原版本没有广告位 直接上传源码到开发者端即可 通过后改广告代码,然后关闭广告展示提交,通过后打开即可 搜索adunit-848e5f13d1ff237a替换为你的Banner 搜索adunit-597…

【Spring学习】Spring Data Redis:RedisTemplate、Repository、Cache注解

1,spring-data-redis官网 1)特点 提供了对不同Redis客户端的整合(Lettuce和Jedis)提供了RedisTemplate统一API来操作Redis支持Redis的发布订阅模型支持Redis哨兵和Redis集群支持基于Lettuce的响应式编程支持基于JDK、JSON、字符…

2013-2022年上市公司迪博内部控制指数、内部控制分项指数数据

2013-2022年上市公司迪博内部控制指数、分项指数数据 1、时间:2013-2022年 2、范围:上市公司 3、指标:证券代码、证券简称、辖区、证监会行业、申万行业、内部控制指数、战略层级指数、经营层级指数、报告可靠指数、合法合规指数、资产安全…

three.js 细一万倍教程 从入门到精通(二)

目录 三、全面认识three.js物体 3.1、掌握几何体顶点_UV_法向属性 3.2、BufferGeometry设置顶点创建矩形 3.3、生成酷炫三角形科技物体 四、详解材质与纹理 4.1、初识材质与纹理 4.2、详解纹理偏移_旋转_重复 偏移 旋转 重复 4.3、设置纹理显示算法与mipmap mapFil…

《UE5_C++多人TPS完整教程》学习笔记8 ——《P9 访问 Steam(Acessing Steam)》

本文为B站系列教学视频 《UE5_C多人TPS完整教程》 —— 《P9 访问 Steam(Acessing Steam)》 的学习笔记,该系列教学视频为 Udemy 课程 《Unreal Engine 5 C Multiplayer Shooter》 的中文字幕翻译版,UP主(也是译者&…

《Linux 简易速速上手小册》第10章: 性能监控与优化(2024 最新版)

文章目录 10.1 理解系统负载10.1.1 重点基础知识10.1.2 重点案例:服务器响应变慢10.1.3 拓展案例 1:多核 CPU 系统的负载解读10.1.4 拓展案例 2:分析具体时间段的系统负载 10.2 优化性能10.2.1 重点基础知识10.2.2 重点案例:优化 …

没更新的日子也在努力呀,布局2024!

文章目录 ⭐ 没更新的日子也在努力呀⭐ 近期的一个状态 - 已圆满⭐ 又到了2024的许愿时间了⭐ 开发者要如何去 "创富" ⭐ 没更新的日子也在努力呀 感觉很久没有更新视频了,好吧,其实真的很久没有更新短视频了。最近的一两个月真的太忙了&#…

CSP-202312-2-因子化简(质数筛法)

CSP-202312-2-因子化简 一、质数筛法 主流的质数筛法包括埃拉托斯特尼筛法(Sieve of Eratosthenes)、欧拉筛法(Sieve of Euler)、线性筛法(Linear Sieve)等。这些算法都用于高效地生成一定范围内的质数。 …

二叉搜索树题目:二叉搜索树的最小绝对差

文章目录 题目标题和出处难度题目描述要求示例数据范围 解法一思路和算法代码复杂度分析 解法二思路和算法代码复杂度分析 题目 标题和出处 标题:二叉搜索树的最小绝对差 出处:530. 二叉搜索树的最小绝对差 难度 3 级 题目描述 要求 给定一个二叉…

java对象内部都有哪些东西

普通对象 对象头 markword 占8字节ClassPointer 指针 :-XX userCompressedClassPointrs 为4字节,不开启为 8字节实例数据 引用类型: -XX userCommpressedOops 为4字节,不开启8字节Padding对齐, 8的倍数 数组对象 对象头:markwor…

算法沉淀——位运算(leetcode真题剖析)

算法沉淀——位运算 常用位运算总结1.基础位运算2.确定一个数中第x位是0还是13.将一个数的第x位改成14.将一个数的第x位改成05.位图6.提取一个数最右边的17.删掉一个数最右边的18.异或运算9.基础例题 力扣题目讲解01.面试题 01.01. 判定字符是否唯一02.丢失的数字03.两整数之和…

【北邮鲁鹏老师计算机视觉课程笔记】05 Hough 霍夫变换

【北邮鲁鹏老师计算机视觉课程笔记】05 Hough 霍夫变换 1 投票策略 考虑到外点率太高 ①让直线上的每一点投票 ②希望噪声点不要给具体的任何模型投票,即噪声点不会有一致性的答案 ③即使被遮挡了,也能把直线找出来 参数空间离散化 直线相当于就是m,b两…

Python 3 中使用 pandas 和 Jupyter Notebook 进行数据分析和可视化

简介 Python 的 pandas 包用于数据操作和分析,旨在让您以直观的方式处理带标签或关联数据。 pandas 包提供了电子表格功能,但由于您正在使用 Python,因此它比传统的图形电子表格程序要快得多且更高效。 在本教程中,我们将介绍如…

git revert回退某次提交

请直接看原文: 【git revert】使用以及理解(详解)_git revert用法-CSDN博客 -------------------------------------------------------------------------------------------------------------------------------- 前言 试验得知:用Reset HEAD方…

笔记---dp---最长上升子序列模型

模型原始题目:AcWing.895.最长上升子序列 题目关系如下: 转化一 AcWing.1017.怪盗基德的滑翔翼 怪盗基德是一个充满传奇色彩的怪盗,专门以珠宝为目标的超级盗窃犯。 而他最为突出的地方,就是他每次都能逃脱中村警部的重重围堵…

ZigBee学习——在官方例程实现组网

✨Z-Stack版本:3.0.2 ✨IAR版本:10.10.1 ✨这篇博客是在善学坊BDB组网实验的基础上进行完善,并指出实现的过程中会出现的各种各样的问题! 善学坊教程地址: ZigBee3.0 BDB组网实验 文章目录 一、基础工程选择二、可能遇…

spring 入门 一

文章目录 Spring简介Spring的优势Spring的体系结构 Spring快速入门Spring程序开发步骤导入Spring开发的基本包坐标编写Dao接口和实现创建Spring核心配置文件在Spring配置文件中配置UserDaoImpl使用Spring的API获得Bean实例 Spring配置文件Bean标签基本配置Bean标签范围配置Bean…