序言

此文出于作者的想法,从各处文章和论文中,总结和设计项目中碰撞结构处理方法。如有其它见解,可以跟作者商讨。(杨子剑,zijian_yang@yeah.net)。

在一个世界中,有多个物体,物体可以分为运动的物体和静止的物体和地形。而世界是很宽广的,本文致力在处理物体之间的碰撞,地形的碰撞后续处理。

处理流程

世界是宽广的,同样世界中物体也是多个的。每个物体一直频繁的检测是浪费效率的(毕竟运动的物体和根本碰不到的物体检测完全没必要)。

分为两个阶段:粗检测(筛选出来会碰撞到的物体) – 细检测(两两碰撞检测)

GJK算法

Gjk算法最初是用来算两个物体的具体,之后因为稳定和快捷,可以用来初检测碰撞。

原理:是算两个物体的顶点差,其实就是距离,得出顶点距离的集合,算出来的多边形是否包含原点,当包含则两物体相交。

SAT分离轴算法

分离轴算法,可以很好的检测出来碰撞点和碰撞点的深度。

原理:当两物体相交,那这两物体从任意方向看过去都是相交的。对应的就是在各个方向的投影都有交叠。

粗检测-空间分割

四叉树

面分割方法,世界大小的正方体是根节点,同等分割四份如果一个物体在一个分支中,找到最小能容纳他的正方体分支。一般情况是根据x y 来分割。

八叉树

空间分割法,其实是比四叉树多一个z的方向的分割,是三维的。

松散四叉树/八叉树

松散八叉树其实是为了解决边界问题,当一个物体在四叉树边缘不断的从一个区域到另一个区域会导致节点不断的更新节点,层级也会发生变化,为了解决这一问题,提出了两个概念。

  1. 入口边界,入口边界等于四叉树/八叉树的真正边缘。
  2. 出口边界,出口边界比四叉树/八叉树的真正边缘大。

 出口边缘具体大多少没有一个明确的定义,大多数为如果边缘的2倍。

当物体移动时,先判断是否出出口边缘,如果没出,则还在当前节点和深度,如果出了则从新寻找入口边缘找到对应的深度和节点。

层次包围盒树

层次包围树用于精确检测,当一个物体的形状是复杂的,多个不规则多边形组合在一起的时候,用此方法最好。例如人由头、身体、手、脚组成,当各个部位运动时,从下往上递归改变父节点的包围盒。

还有一种用法是,当其中一个物体在空间中改变位置的时候,pop形状-刷新分支节点包围盒-重新加入包围盒树,计算bvh。

一般包围盒形状是统一的,aabb、球、或者box。

球构造很快(圆心和半径)。

碰撞检测快,因为当父节点aabb不想交或者射线检测不到,则子节点无需检测。

细检测-运动中物体检测

当物体在代码中模拟运动的时候,是离散的状态,每次经过dt的时间计算下一次的碰撞。碰撞的两物体因为dt的时间长短,很有可能发生穿插的问题。下面介绍了两种检测方法。

连续碰撞检测

把这段状态积分化,或者函数化,求导数的极致,来求得最后在dt中某个时间的碰撞。大连理工大学机械工程学院《凸多面体连续碰撞检测的运动轨迹分离轴算法》- 2013

1月张应中发表,这篇论文实际是应用了gjk的理论,并加上射线检测,求得最终的碰撞点。里面的算法名称叫做lccd。

天津大学电气与自动化工程学院《基于gjk的凸体快速连续碰撞检测研究》-2014年10月刘丽发表,fccd算法,用于连续检测碰撞。

上述两种检测算法,因为都需要模拟中间一段的求极值得过程,实际效率并不如下面的非连续碰撞检测。优点则是可以准确的求得当前碰撞的时间和点。

非连续碰撞检测

非连续碰撞其实跟当前dt一样,求当前帧是否碰撞。但如果精度不够,可以继续缩小精度,当人物在dt的过程中,可以认为一切的变化都是线性的,所以可以通过线性求得dt/8(再细分8次)的过程的装态,判断8次中有没有碰撞。如果精度不够,则可以再继续划分精度,求得更精细的离散过程。中间当然可以先判断是否有可能在离散过程中可能碰撞。

物体与场景碰撞

其实是物体跟三角形求出最近点,不让穿透。射线检测求相交。

物体形状碰撞效率

多边形和不规则多边形的碰撞检测,有规律的多边形,一般为三角面,长方体(box),aabb包围盒、球体、胶囊体。圆柱等。

不规则的多边形需要是凸多边形(gjk和sat算法都需要是凸多边形),如果不是,需要通过算法来把一个物体变为多个形状。

现有的算法三角面、aabb、球体、胶囊体是可以通过他们的特殊性快读求得相交。而其他的需要通过sat具体来算出交点。Sat是a边型与b边型求交, 如果不交,则很快能得出, 相交需要判断O(a*b)。

总结

 算法最后还需要根据实际场景来选择。

世界碰撞算法原理和总结(sat gjk)的更多相关文章

  1. (转)RSA算法原理

    RSA算法原理(二)   作者: 阮一峰 日期: 2013年7月 4日 上一次,我介绍了一些数论知识. 有了这些知识,我们就可以看懂RSA算法.这是目前地球上最重要的加密算法. 六.密钥生成的步骤 我 ...

  2. 微信技术分享:微信的海量IM聊天消息序列号生成实践(算法原理篇)

    1.点评 对于IM系统来说,如何做到IM聊天消息离线差异拉取(差异拉取是为了节省流量).消息多端同步.消息顺序保证等,是典型的IM技术难点. 就像即时通讯网整理的以下IM开发干货系列一样: <I ...

  3. 【PPT详解】曹欢欢:今日头条算法原理

    [PPT详解]曹欢欢:今日头条算法原理 悟空智能科技 4月8日 公众号后台回复:“区块链”,获取区块链报告 公众号后台回复:“sq”,进入区块链分享社群 热文推荐: 1000位专家推荐,20本区块链必 ...

  4. Paxos发展、算法原理

    Paxos 发展史 Leslie Lamport所提出的Paxos算法是现代分布式系统中的一项重要的基础性技术,得到广泛的应用. Paxos的整个发展过程大概可以分为三个阶段: 第一阶段:萌芽期,大致 ...

  5. 如何做系列(4)-微博URL短网址生成算法原理(java版、php版实现实例)

    短网址(Short URL),顾名思义就是在形式上比较短的网址.通常用的是asp或者php转向,在Web 2.0的今天,不得不说,这是一个潮流.目前已经有许多类似服务,借助短网址您可以用简短的网址替代 ...

  6. Bagging与随机森林算法原理小结

    在集成学习原理小结中,我们讲到了集成学习有两个流派,一个是boosting派系,它的特点是各个弱学习器之间有依赖关系.另一种是bagging流派,它的特点是各个弱学习器之间没有依赖关系,可以并行拟合. ...

  7. RSA算法原理

    一直以来对linux中的ssh认证.SSL.TLS这些安全认证似懂非懂的.看到阮一峰博客中对RSA算法的原理做了非常详细的解释,看完之后茅塞顿开,关于RSA的相关文章如下 RSA算法原理(一) RSA ...

  8. LruCache算法原理及实现

    LruCache算法原理及实现 LruCache算法原理 LRU为Least Recently Used的缩写,意思也就是近期最少使用算法.LruCache将LinkedHashMap的顺序设置为LR ...

  9. MySQL索引背后的数据结构及算法原理【转】

    本文来自:张洋的MySQL索引背后的数据结构及算法原理 摘要 本文以MySQL数据库为研究对象,讨论与数据库索引相关的一些话题.特别需要说明的是,MySQL支持诸多存储引擎,而各种存储引擎对索引的支持 ...

随机推荐

  1. 图形渲染的大致过程和关于OpenGL渲染管线的一些零碎知识,openglpipeline,vao,vbo,ebo.

    重要!!! OpenGL新人一枚,希望可以再此和大家分享有用的知识,少走弯路 文章会定期更新,把前面几段已经整理过的知识更完后,接下来每周至少会更两次. 文章如果有不对的,理解错误的地方,也非常希望在 ...

  2. 理解 JAVABEAN EJB POJO

    <Spring实战>第一章:基本理念.各类名称熟语 POJO(Plain Ordinary Java Object)简单的Java对象,实际就是普通JavaBeans,是为了避免和EJB混 ...

  3. 关于TCP建立连接

    TCP大家大多称之为"三次握手".今天看了一篇文章,学到了"三步握手". TCP建立连接,客户端发送SYN给服务端,服务端接收到请求回应ACK.服务端发送SYN ...

  4. 渗透测试方法论(qf总结)

    渗透测试(penetration testing , pentest)是实施安全评估(即审计)的具体手段.方法论是在指定.实施信息安全审计方案时,需要遵循的规则.惯例和过程.人们在评估网路.应用.系统 ...

  5. 【extern】【static】

    C语言根据变量的生存周期来划分,可以分为静态存储方式和动态存储方式. 静态存储方式:是指在程序运行期间分配固定的存储空间的方式.静态存储区中存放了在整个程序执行过程中都存在的变量,如全局变量. 动态存 ...

  6. “酒香也怕巷子深” Smartflow-Sharp 工作流

    导语 老话说得好,"酒香不怕巷子深"可是我又不是什么大咖,写得再好也没人知道.所以我今天准备再写写我的工作流组件,写得不好还请大家见谅.写文章对于我来说,有点感觉"茶壶里 ...

  7. 067 01 Android 零基础入门 01 Java基础语法 08 Java方法 05 数组作为方法参数

    067 01 Android 零基础入门 01 Java基础语法 08 Java方法 05 数组作为方法参数 本文知识点:数组作为方法参数 说明:因为时间紧张,本人写博客过程中只是对知识点的关键步骤进 ...

  8. Docker---初识到使用

    1.剖析虚拟化技术概念 1)虚拟化是一个主流的技术,虚拟的,看不见的,但是可以落地的,用于资源管理的一项技术: 2)虚拟化的技术诞生的目标就是为了解决资源管理和资源利用的解决方案: 3)虚拟化就是将物 ...

  9. 批处理中的删除命令:del

    转载:https://blog.csdn.net/playboy1/article/details/6869358 删除一个或数个文件.DEL [/P] [/F] [/S] [/Q] [/A[[:]a ...

  10. Hive理论基础

    数仓特征:面向主题,集成,非易失的,时变.数据仓库是在数据库已经大量存在的情况下,为了进一步挖掘数据资源.为了决策需要而产生的,不是所谓的"大型数据库".   数据库与数据仓库的区 ...