计算机图形学入门games103——碰撞检测

一.怎么发现碰撞,有没有碰撞

碰撞最难的是布料的碰撞

碰撞检测分为两个部分:

第一阶段:去除不可能发生碰撞的元素,输出的就是可能碰撞的备选目标,这阶段叫做碰撞剔除

这常用的套路有两种:第一种是Spatial Hashing,第二种是BVH(Bounding Volume Hirearchy)

Spatial Hashing:

将整个空间划分成很多的小区域,对每一个元素在空间上的分布存入进去,存储后,做相交检测就很容易了,如下图所示,我要想知道t3和哪一些其他的三角形有可能相交,我只需要搜寻t3存在哪些小区域中,这些小区域中有哪些其它的三角形就可以了,这里就有t0和t5

那么如果是运动的话,只要根据运动轨迹,将轨迹上的小区域都存进去就可以了,这样的问题是存储量太大了,而且事先我并不知道要存入多少三角形,而且有大量的可能是空的                            这个解决方法就是先存入序列,然后再根据小区域的顺序进行排序,这样可优化内存,对每一个区域存入一个开始和结束的位置,我需要知道几号区域有三角形,直接访问几号区域的开始指针就可以了

这样的话还有一个问题,内存的访问不够连续,无法有效利用到缓存的优势,内存访问的跨度会很大,这样下来有一个新的套路,对整个空间进行细分,优化整个数据访问的连续性

这里有一个基于空间划分的方法进行碰撞的教程例子,英伟达在GPU上对于碰撞的实现

BVH(Bounding Volume Hirearchy):

有别于对于空间进行划分,对于一个有规律的物体,我们可以根据物体的结构进行划分,也就是包围盒的方法,我们可以通过包围盒做一些筛选,快速剔除不会发生碰撞的元素对,基于小的包围盒,我可以从上至下做一个层级的包围盒,,这样在和外部物体以及内部检测方面都会很方便,如下是一个简单的例子

自上而下一个一个的遍历过来,那么对于自相交的处理,比如说对于整体的节点,我们可以通过递归的方式来检测有没有自相交,然后检测子节点有没有相交,然后检查子节点的子节点

包围盒有很多种,其中比较容易也比较常见的就是AABB包围盒,不需要进行数值计算,只需要进行一个大小的比较就可以了,用的最多的就是AABB这种横平竖直的包围盒,但是这种方法很难做和近邻的相交,这个方法使用了能量剔除的方法,特别是对于弹性体使用这个是比较好的

两种方法对比的话,空间划分的方法写起来相对还比较容易,对于GPU也比较友好,但是计算资源的消耗是比较高的,若是包围盒的代码写起来就比较麻烦,对于GPU也不太友好,因为是树的结构,但是这种方法更新起来比较容易

第二阶段:根据处理可能分为连续的检测和离散的检测,这部分输出真正发生碰撞的对象进行检测

离散的检测:

这其实真正检测的是相交,对于边和三角形是否相交,DCD没有运动的概念,并不是真正的检测碰撞,相交和碰撞是有区别的,没有相交不等于没有碰撞,物体如果运动的比较快的话,可能就检测不到相交

连续的检测:

也就是真正的碰撞检测算法,那么对于一个三角形而言,我们需要检测的就是状态之间点—三角形,边—边的检测

做连续的碰撞检测计算量要比离散的要大一些,当然,连续的碰撞检测计算量只是模拟的小头,不用太在意,写起来也比较复杂,在游戏中大家使用的更多是DCD,也就是离散的碰撞检测,除非需要特别高的精度,如果是在手术模拟这种需要满足实时性的碰撞检测的时候,也大多使用DCD离散的碰撞检测

2.内点法

在我们发现碰撞了之后,我们需要怎么处理,内点法的处理思路是。我保证我的点一直在合理区域内,一直去接近最优解(这样比较慢),永远可以成功

实现方法,步长的选择很重要,每走一步都要进行碰撞检测

3.冲击区优化

这个就是直接不断优化不安全的结果到安全的结果,比较快,只需要集中优化一个区域就可以了,但有可能在步长很大的情况下失败

                

4.离散碰撞

当我发现有可能发生碰撞,我就回到前一帧,封住整个区域,下面是实现连续碰撞的思路

相交处理:

对于有体积的物体来说,如果有相交,把物体推出去就可以了,例如之前球和布料的模拟,或者那个弹性体的模拟

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

算法题解记录26+++翻转二叉树(百日筑基)

题目描述: 题目难度:简单 给你一棵二叉树的根节点 root ,翻转这棵二叉树,并返回其根节点。 示例 1: 输入:root [4,2,7,1,3,6,9] 输出:[4,7,2,9,6,3,1]示例 2: 输入:roo…

C++ TCP发送Socket数据

DEVC需要加入ws2_32库 #include <iostream> #include <winsock2.h>#pragma comment(lib, "ws2_32.lib")void sendData(const char* ip, int port, const char* data) {WSADATA wsaData;SOCKET sockfd;struct sockaddr_in server_addr;// 初始化Winsock…

HDR视频相关标准-HDR vivid(二)

上文介绍了HDRvivid的一些技术。今天从全局角度来看看HDR视频的处理流程&#xff0c;HDR视频系统&#xff0c;即建立一个比SDR视频更大的色彩/亮度坐标体系&#xff0c;并改变系统的传输函数&#xff0c;以再现更大的色域(WCG)和更高的亮度动态范围。 菁彩 HDR技术的专业术语 …

(全面)Nginx格式化插件,Nginx生产工具,Nginx常用命令

目录 &#x1f3ab; 前言 &#x1f389; 开篇福利 &#x1f381; 开篇福利 x2 Double happiness # 介绍 # 地址 # 下载 &#x1f4bb; 命令及解析 # 整个文件系统中搜索名为nginx.conf的文件 # 编辑nginx.conf文件 # 重新加载配置文件 # 快速查找nginx.conf文件并使…

python的协程异步

参考资料 https://blog.csdn.net/qq_43380180/article/details/111573642?spm1001.2014.3001.5506 协程的概念 指的是在一个线程中&#xff0c;可以在某个地方挂起的特殊函数&#xff0c;并且可以重新在挂起处继续运行。协程不是进程&#xff0c;也不是线程。 进程 VS 线程…

Polar 上传

Polar 上传 开题&#xff0c;是一个文件上传界面 对文件后缀有过滤 测试了一下是黑名单&#xff0c;过滤了php相关的文件&#xff0c;但是没过滤.ini、.htaccess后缀的文件 对内容的过滤是<?、file&#xff0c;所以不能用.user.ini配置文件绕过 我们选择使用.htaccess配置…

晶体振荡器

一、晶振与晶体区别 晶振是有源晶振的简称&#xff0c;又叫振荡器&#xff0c;英文名称是oscillator&#xff0c;内部有时钟电路&#xff0c;只需供电便可产生振荡信号&#xff1b;晶体是无源晶振的简称&#xff0c;也叫谐振器&#xff0c;英文名称是crystal&#xff0c;是无极…

第197题|奇偶性的四则运算,你掌握了吗?|函数强化训练(四)|武忠祥老师每日一题 5月22日

解题思路&#xff1a;这道题如果我们会21号的题的话&#xff0c;简直是小菜一碟&#xff01;主要就是要用到下面这个结论&#xff1a; &#xff08;A&#xff09; 直接看奇偶性我们不好看&#xff0c;我们需要拆项&#xff1a; 我们先看前一项的奇偶性&#xff0c;x是奇函数&a…

民国漫画杂志《时代漫画》第13期.PDF

时代漫画13.PDF: https://url03.ctfile.com/f/1779803-1247458360-14efab?p9586 (访问密码: 9586) 《时代漫画》的杂志在1934年诞生了&#xff0c;截止1937年6月战争来临被迫停刊共发行了39期。 ps:资源来源网络&#xff01;

P1【知识点】【数据结构】【链表LinkedList】C++版

链表是一种逻辑上连续&#xff0c;内存上分散的线性表数据结构&#xff0c;是用一组任意的空间&#xff08;可以连续&#xff0c;也可以不连续&#xff09;来存放数据元素。每个数据元素成为一个”结点“&#xff0c;每个结点由数据域和指针域组成。 访问元素&#xff08;Acce…

特征融合篇 | YOLOv8改进之引入轻量级跨尺度特征融合模块CCFM | 源自RT-DETR

前言:Hello大家好,我是小哥谈。CCFM(Cross-Scale Feature Fusion Module)即为跨尺度特征融合模块。这个模块的作用是将不同尺度的特征通过融合操作整合起来,以增强模型对于尺度变化的适应性和对小尺度对象的检测能力。CCFM可以有效地整合细节特征和上下文信息,从而提高模…

【全开源】简单商城系统(PC/UniAPP)

轻松构建您的在线商店 在当今数字化时代&#xff0c;拥有一个在线商店对于许多商家来说已成为必不可少的营销手段。为了满足这一需求&#xff0c;我们推出了“简单商城系统源码”&#xff0c;让您轻松构建并管理您的在线商店。 一、简单易用&#xff0c;快速上手 “简单商城…

python demo

文章背景&#xff0c;记录python 小demo 集合 1、使用python matplotlib库描绘曲线 import matplotlib.pyplot as NLAx_index [0, 5, 10, 15, 20, 25, 30, 35, 40, 45, 50, 55, 60, 65, 70, 75, 80, 85, 90, 95, 100] y_index [6.1, 7.4, 9.1, 11.1, 12.69, 14.35, 16.1, 1…

成都爱尔周进院长提醒当双眼度数差距过大,我们该做些什么

每个人的用眼方式、用眼习惯且两只眼睛“天生条件”不一定相同&#xff0c;当发生近视&#xff0c;双眼近视程度也就可能不同&#xff0c;双眼度数必然会变得不一样。当双眼度数产生差异&#xff0c;尤其是当双眼度数差别过大时会引发哪些问题&#xff1f; 双眼度数不一致&…

面试八股之MySQL篇4——事务篇

&#x1f308;hello&#xff0c;你好鸭&#xff0c;我是Ethan&#xff0c;一名不断学习的码农&#xff0c;很高兴你能来阅读。 ✔️目前博客主要更新Java系列、项目案例、计算机必学四件套等。 &#x1f3c3;人生之义&#xff0c;在于追求&#xff0c;不在成败&#xff0c;勤通…

【ARFoundation自学03】AR Point Cloud 点云(参考点标记)功能详解

和平面识别框架一样 1为XR Origin添加AR Point Cloud Manager组件 然后你的ar应用就具备了点云识别功能&#xff0c;就这么简单 2.可视化这些云点 创建一个美术效果的预制体&#xff0c;人家提供了预设模板 然后拖到仓库&#xff08;ASSETS&#xff09;创建预制体&#xff…

Redis持久化之☞AOF、AOF是怎样执行持久化的?

AOF持久化机制&#xff1a; AOF&#xff08;Append Of File&#xff09;&#xff1a;将redis执行过的所有写指令记录下来&#xff0c;在下次redis重新启动时&#xff0c;只要把这些指令从前到后重复执行一遍&#xff0c;就可以实现数据恢复了。 以独立日志的方式记录每次写命…

本特利330878-90-00前置传感器在PLC系统中的应用与优势

本特利330878-90-00前置传感器在PLC系统中的应用与优势 一、引言 在现代工业自动化领域中&#xff0c;传感器作为信息获取的重要工具&#xff0c;其性能的稳定性和准确性直接影响到整个系统的运行效率。其中&#xff0c;本特利330878-90-00前置传感器以其卓越的性能和广泛的应…

查看主机的php参数short_open_tag 是否为 on

我想要查看主机的php参数short_open_tag 是否为 on&#xff0c;由于我使用的是Hostease的Linux虚拟主机产品&#xff0c;在cPanel面板中并没有找到这个参数选项&#xff0c;因此无法查看。这边联系了Hostease技术支持了解&#xff0c;可以通过以下方式进行查看。 1.先登陆cPane…

自定义横向思维导图,横向组织架构图,横向树图。可以自定义节点颜色,样式,还可以导出为图片

最近公司设计要求根据目录结构&#xff0c;横向展示。所以做了一个横向的思维导图&#xff0c;横向的树结构&#xff0c;横向的组织架构图&#xff0c;可以自定义节点颜色&#xff0c;样式&#xff0c;还可以导出为图片 话不多说&#xff0c;直接上图片&#xff0c;这个就是一…