当前位置: 首页 > news >正文

四川建设安全监督管理局网站/百度一下 你就知道官网

四川建设安全监督管理局网站,百度一下 你就知道官网,企业网站教程 优帮云,动漫设计与制作毕业论文八叉树碰撞检测是一种在三维空间中高效处理物体碰撞检测的算法,其原理可以类比为一个管理三维空间物体的智能系统。这个示例包含两个部分:八叉树部分用于宏观检测,AABB用于微观检测。AABB可以更换为均值或节点检测来提高检测精度。 八叉树的…

八叉树碰撞检测是一种在三维空间中高效处理物体碰撞检测的算法,其原理可以类比为一个管理三维空间物体的智能系统。这个示例包含两个部分:八叉树部分用于宏观检测,AABB用于微观检测。AABB可以更换为均值或节点检测来提高检测精度。

八叉树的构建

  1. 确定根节点范围
    首先要为整个碰撞检测系统确定一个初始范围,这就像是为所有参与碰撞检测的物体划定一个 “活动区域”。这个范围是一个能够完全容纳所有待检测物体的三维立方体空间,它构成了八叉树的根节点。
  2. 递归分割空间
    为了更高效地管理和查找物体,八叉树会对这个初始的大立方体空间进行递归分割。具体做法是沿着三个坐标轴的中点,将大立方体分割成八个小立方体,每个小立方体对应根节点的一个子节点。之后,系统会检查每个子节点所包含的物体数量:
    若某个子节点中的物体数量小于预设的阈值,就认为该区域内的物体分布较为稀疏,无需再进行分割,这些物体就存储在该节点中。
    若物体数量超过阈值,说明该区域物体较为密集,需要进一步细分。于是会将这个节点的空间继续分割成八个更小的子空间,并对每个子空间重复上述检查过程,直到满足停止条件。
    碰撞检测过程
  3. 插入物体
    在将物体的轴对齐包围盒(AABB)插入八叉树时,系统会从根节点开始判断物体的 AABB 与当前节点的空间是否相交:
    如果不相交,表明该物体不在当前节点所管理的空间范围内,无需在此节点存储该物体。
    如果相交,则将物体插入当前节点。若当前节点已经被分割成子节点,系统会进一步判断物体的 AABB 与哪个子节点的空间相交,并将物体插入对应的子节点中。
  4. 查询碰撞
    当需要检测某个物体(用其 AABB 表示)是否与其他物体发生碰撞时,系统会从八叉树的根节点开始查询:
    若该物体的 AABB 与当前节点的空间不相交,说明该节点及其子节点中的物体都不可能与该物体发生碰撞,无需继续检查该节点及其子树。
    若相交,则检查当前节点中存储的物体的 AABB 与该物体的 AABB 是否相交。
    若当前节点有子节点,系统会递归地对每个子节点进行相同的查询操作,直到遍历完所有可能发生碰撞的节点。
    八叉树碰撞检测的优缺点
    优点
    高效性:通过对三维空间进行递归分割,八叉树将碰撞检测的范围缩小到可能发生碰撞的区域,避免了对所有物体进行两两比较,从而显著减少了不必要的计算,提高了碰撞检测的效率。在处理大量物体的场景中,这种优势更为明显。
    适应性:八叉树能够根据物体在空间中的实际分布情况自适应地进行空间划分,对于物体分布不均匀的场景也能有效地组织和管理物体。
    缺点
    构建和维护成本较高:构建八叉树需要对空间进行递归分割,并将物体分配到相应的节点中,这需要一定的时间和空间开销。特别是在物体频繁移动或新增、删除物体的场景中,需要不断更新八叉树的结构,增加了维护成本。
    存在精度问题:使用 AABB 来近似表示物体可能会导致一定的精度损失,尤其是对于形状复杂的物体,AABB 可能无法精确地描述其外形,从而产生误判。

C++代码

#include <iostream>
#include <vector>
#include <memory>// 定义三维向量结构体
struct Vec3 {float x, y, z;Vec3(float x = 0, float y = 0, float z = 0) : x(x), y(y), z(z) {}
};// 定义 AABB 结构体
struct AABB {Vec3 min;Vec3 max;AABB(const Vec3& min, const Vec3& max) : min(min), max(max) {}// 判断两个 AABB 是否相交bool intersects(const AABB& other) const {return (min.x <= other.max.x && max.x >= other.min.x) &&(min.y <= other.max.y && max.y >= other.min.y) &&(min.z <= other.max.z && max.z >= other.min.z);}
};// 定义八叉树节点类
class OctreeNode {
public:AABB bounds;std::vector<AABB> objects;std::vector<std::unique_ptr<OctreeNode>> children;OctreeNode(const AABB& bounds) : bounds(bounds) {}// 插入 AABB 到节点中void insert(const AABB& object) {if (children.empty()) {if (objects.size() < 8) {objects.push_back(object);} else {split();insert(object);}} else {for (auto& child : children) {if (child->bounds.intersects(object)) {child->insert(object);}}}}// 分割节点void split() {Vec3 center((bounds.min.x + bounds.max.x) / 2, (bounds.min.y + bounds.max.y) / 2, (bounds.min.z + bounds.max.z) / 2);children.resize(8);children[0] = std::make_unique<OctreeNode>(AABB(bounds.min, center));children[1] = std::make_unique<OctreeNode>(AABB(Vec3(center.x, bounds.min.y, bounds.min.z), Vec3(bounds.max.x, center.y, center.z)));children[2] = std::make_unique<OctreeNode>(AABB(Vec3(bounds.min.x, center.y, bounds.min.z), Vec3(center.x, bounds.max.y, center.z)));children[3] = std::make_unique<OctreeNode>(AABB(Vec3(center.x, center.y, bounds.min.z), Vec3(bounds.max.x, bounds.max.y, center.z)));children[4] = std::make_unique<OctreeNode>(AABB(Vec3(bounds.min.x, bounds.min.y, center.z), Vec3(center.x, center.y, bounds.max.z)));children[5] = std::make_unique<OctreeNode>(AABB(Vec3(center.x, bounds.min.y, center.z), Vec3(bounds.max.x, center.y, bounds.max.z)));children[6] = std::make_unique<OctreeNode>(AABB(Vec3(bounds.min.x, center.y, center.z), Vec3(center.x, bounds.max.y, bounds.max.z)));children[7] = std::make_unique<OctreeNode>(AABB(center, bounds.max));for (const auto& object : objects) {for (auto& child : children) {if (child->bounds.intersects(object)) {child->insert(object);}}}objects.clear();}// 检测与指定 AABB 的碰撞void query(const AABB& object, std::vector<AABB>& result) const {if (bounds.intersects(object)) {for (const auto& obj : objects) {if (obj.intersects(object)) {result.push_back(obj);}}for (const auto& child : children) {child->query(object, result);}}}
};// 定义八叉树类
class Octree {
public:std::unique_ptr<OctreeNode> root;Octree(const AABB& bounds) : root(std::make_unique<OctreeNode>(bounds)) {}// 插入 AABB 到八叉树中void insert(const AABB& object) {root->insert(object);}// 检测与指定 AABB 的碰撞std::vector<AABB> query(const AABB& object) const {std::vector<AABB> result;root->query(object, result);return result;}
};// 示例使用
int main() {// 定义八叉树的边界AABB octreeBounds(Vec3(0, 0, 0), Vec3(100, 100, 100));Octree octree(octreeBounds);// 插入一些 AABBoctree.insert(AABB(Vec3(10, 10, 10), Vec3(20, 20, 20)));octree.insert(AABB(Vec3(30, 30, 30), Vec3(40, 40, 40)));// 定义一个查询的 AABBAABB queryAABB(Vec3(15, 15, 15), Vec3(25, 25, 25));// 进行碰撞检测std::vector<AABB> collisions = octree.query(queryAABB);// 输出碰撞结果std::cout << "Collisions found: " << collisions.size() << std::endl;for (const auto& collision : collisions) {std::cout << "Collision: min(" << collision.min.x << ", " << collision.min.y << ", " << collision.min.z << "), max("<< collision.max.x << ", " << collision.max.y << ", " << collision.max.z << ")" << std::endl;}return 0;
}
http://www.whsansanxincailiao.cn/news/31969452.html

相关文章:

  • 百度云做网站/微信营销策略
  • 网上做二建题那个网站好/青岛网站排名推广
  • 佛山网站上排名/搜索网
  • 企业公司网站制作/提升神马关键词排名报价
  • 深圳人为什么不想去龙岗/郑州seo排名哪有
  • 西宁公司做网站/百度网站的网址
  • 做外贸的免费网站有哪些/提高工作效率
  • 邵阳县网站建设公司沙河网站建设公司/网络营销形式
  • 网站建设与管理怎么做/徐州百度推广
  • wordpress 导入discuz/宁波seo深度优化平台有哪些
  • 动易网站中添加邮箱/电商平台排行榜前十名
  • 如何做制作头像的网站/网站流量分析报告
  • 东莞微信网站建设更好/活动推广方案怎么写
  • 大连建网站/蜂蜜网络营销推广方案
  • 宁波网站建设明细报价/亚马逊alexa
  • 六安做网站多少钱/自己怎么做网页
  • 衡阳建设企业网站/注册网站流程
  • 衡阳网站推广排名/招商外包公司
  • 找工程哪个平台最可靠/广州seo推广运营专员
  • 成都定制网站设/seo排名关键词
  • 昆山科技网站建设/中国十大企业管理培训机构
  • 方庄网站建设公司/百度搜索提交入口
  • 成安网站建设/seo是什么部门
  • wordpress数据库用户角色/seo百度关键字优化
  • 昆山网站建设哪家便宜/seo信息网
  • 阿里巴巴网站建设基本内容/手机创建网站免费注册
  • 交互式网站备案难吗/短视频营销的发展趋势
  • 成都 企业 网站制作/成都seo优化
  • 制作网站副本/微信推广多少钱一次
  • 作业做哪些类型的网站/今日头条新闻推荐