作者: 马良 ( )
原帖地址
0 前提假设 计算机图形学中的物理模拟实际上只是追求视觉近似,而并非精确的物理模拟 同时物理引擎从简化计算考虑, 不与渲染引擎共享对象数据采用独立的一套数据.1 架构分析 物理模拟的基础是建立在一些核心几何结构之上. 核心的几何概念有
- 形 状 (shape) : shape 抽象出了几何形状的特征, 比如长方体, 球, 四面体,凸包. bullet中的形状类型非常丰富有几十种之多. 由于几何形状的特征是和具体对象无关的,所以一种形状只要维持一个实例即可, 所有映射到该shape的对象可以共享这个实例.
- 包围体层次(BVH) 这个的概念可以在书中查找,一般有AABB, OBB, K-Dop, Convex Hull. Bullet 中采用的是AABB
- 空间划分数据机构节点 bullet 采用AABB
- 空间划分数据结构(通常是树) Bullet 中采用的主要是Dynamic AABB Tree (刚体 , 值得注意的是这里用得是曼哈顿距离) 和 Sweep and Prune (soft body)
- 碰撞检测算法(这里也有很多选择完全根据检测对象来定,GJK ,sweep prune 是复杂的, box2box, shpere2shpere .... 比较简单.
- 接触点(contract point, manifold)
- 约束类型(bullet 提供了6种,见bullet 手册)
- motion state 是对渲染引擎提供的一个接口, 便于渲染引擎更新渲染对象的位置
完 成几何基础构建后在一个场景(collision world)内 加入 各个被模拟的物理对象(collision object)每个物理对象被映射到对映的shape, 空间划分数据结构节点. 如果再在这些对象身上附加例如速度,角速度,转动惯量等物理特征,就演化为rigid object. Soft body 情况复杂一些, 一般由mesh构成 尚在分析中. 物理模拟过程分为2个主要阶段.
- Broad Phase: 首先进行远距碰撞检测, 利用空间分割结构,如果不在同一个子树内的物体不可能相交不用去计算, 在同一个子树内的物体被放入 overlapping pair, 再进一步由对应的算法来计算出接触点等信息. 采用哪一种算法取决于算法配置矩阵(见bullet 手册)
- Narrow Phase: 根据overlapping pairs 的分布情况计算出碰撞对象岛(collision Island).而后依次对各个岛进行约束分析. 亦即碰撞响应. Bullet 采用的是Sequential Impulse ConstraintSolver(http://www.gphysics.com/archives/28) 约束分析是一个非常复杂的话题,涉及到PGS算法的简化,后文会有介绍. 约束分析会根据所设定的约束类型来计算碰撞后各个对象所对应的位置,速度等, 然后与渲染引擎同步motion state.
- 理论准备:本科的数学分析,理论力学,线性代数。 尤其是理论力学中的朗格朗日动力学部分 最好能回忆起来。 碰撞检测上面列的两本书的内容就足够了,如果进一步挖掘需要看 计算几何方面的书
- 补一个架构图 引自[1]的12页,其中的STC即为上次分析中的islandmanager
碰撞响应的分析
- 约束分类:可积约束,不可积约束 ,摩擦力(见[1]第四章)
- 整个bullet在动力学方面的核心就是btSequentialImpulseConstraintSolver 这个类及其实现这个类名字可以翻译为基于顺序冲量处理方法的约束求解过程(这是个缩略的函数名不可直译)。这个名字的含义很重要,表示了这个求解方法是按照顺序来处理约束以及接触点,摩擦力,one by one并且求解的结果是冲量的范数。整个的原理部分可以参照[1]的第4章节,[2]的第7章。
- btSequentialImpulseConstraintSolver 的全部重心在于solveGroupCacheFriendlySetup 负责对于三种约束进行计算准备(包括计算一些解方程要用到的常量以及中间变量等)和 solveGroupCacheFriendlyIterations 负责应用PGS[9]求解。
- 首先是关于可积约束的计算准备:首先是遍历约束数组,每一个约束都需要计算自己的jacbian(关键概念参照[1]的第四章)初始化一些常量和中间变量 这里有些概念和公式比如惯性张量等都可以在[1],[8]中找到
- 关于接触点约束的计算准备:这里有个重要的函数convertContact, 把从碰撞检测阶段获得的接触点转化为不可积约束并初始化常量和中间变量,以及初始化摩擦力的相关数据,摩擦力计算参照[1]第4章第6节 其中引用的公式也来自[1] 但是考虑到实时性,并不完全一致。
- 分别根据[9]中的PGS算法求解3类约束,重点是基于SIMD的优化,以及递归次数10的设置。 对于PGS的理解最好从Gauss-Sidel数值解法入手。 对于各类约束类型对应的jacbian 参照[1]第四章节71页
- 核心的数据结构 btSolverConstraint 存储每个约束的计算常量中间变量 btSolverBody 几何刚体对象和动力学求解对象的连接体
- 其它 整个过程中涉及到了穿透矫正[1]111页,时间递进[1]90页,bullet 没有采用多接触点同时求解的方法,会带来一些误差
[1]的第4章是整个动力学模拟的灵魂,理解了这章,整个求解过程都容易理解
下一步计划写softbody的分析参考书目[1]Stable, Robust, and Versatile Multibody Dynamics AnimationKenny Erleben关于多刚体-动力学模拟必读的文章 bullet很多实现都参考了此文很好的一篇综述论文,实际上是下面这本书的草稿网上可以下到免费的pdf版本[2]physics based animation Kenny Erleben同作者的一本全面且用较为严格的数学语言描述物理模拟的经典好书涵盖刚体,流体,非刚体国内尚未引进,目前暂无电子版。 适合深度挖掘者使用。[3]Game Physics, David H. Eberly从游戏开发角度来阐释物理模拟,比较实用,内容稍显陈旧。 有电子版,不好找[4]Physics.Engine.Development同样是阐述物理模拟,不过是为入门读者准备,比较浅显易懂。 有电子版[5]Collision Detection in Interactive 3D Environments对照作者自己实现的solid碰撞检测引擎来讲述,很好的一本书。又电子版[6]Real-Time Collision Detection比较全面的阐述了碰撞检测,是一个初步入门的好书, 有电子版[7]Computational Geometry in C如果想在几何结构方面进一步挖掘,这本书不错,清华翻译的二版有卖,翻译的也好三版已出,似乎还没引进[8]Classical Mechanics. Prentice Hall, 3rd edition, January 2002.理论力学,很多东西忘记了可以查看这本书 有电子版[9]Iterative Dynamics with Temporal Coherence一篇在GDC2005?上的ppt,简短描述有关PGS算法的问题,是Box2D的作者