news 2026/5/16 7:47:20

3D点云KD树搜索:空间里的“寻宝地图“

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
3D点云KD树搜索:空间里的“寻宝地图“

3D点云KD树搜索:空间里的"寻宝地图"

今天我来用最生活化的方式解释3D点云KD树搜索

3D点云是什么?想象一下"撒满星星的夜空"

想象你用激光扫描仪扫描一个雕像,结果得到的是无数个点,每个点都有x、y、z三个坐标(就像在三维空间里标出位置)。这些点合起来就叫"点云",就像夜空中撒满的星星,但没有连接关系,每个星星都是独立的。

关键点:点云数据量巨大,一个简单的3D扫描可能有数百万个点!

KD树怎么工作?"切蛋糕"的三维版(文字示意图)

想象你有一块3D的蛋糕(立方体形状),上面撒满了小点(代表点云数据)。KD树就是把这块蛋糕"切"成小块,让搜索变得高效。

1. KD树构建过程(文字示意图)

Z ^ | (9,6,3) ← 右子树 | / | / |/ +-------> X / / / / Y (7,2,3) ← 根节点 (x轴分割) / \ / \ / \ / \ (5,4,2) (8,1,5) ← 右子树 / \ / \ / \ / \ (2,3,1) (4,7,3) (8,1,5) (9,6,3) ← 叶子节点

构建步骤

  1. 第一刀:在x轴方向切,中位数x=7 → 左边x<7,右边x≥7
  2. 第二刀:对左边的点在y轴方向切,中位数y=4 → 前面y<4,后面y≥4
  3. 第三刀:对右边的点在y轴方向切,中位数y=6 → 前面y<6,后面y≥6
  4. 继续切:在x轴方向切,然后y轴,z轴,交替进行

关键点:KD树是"交替切",不是每次都切同一个方向,这样能保证树的平衡。

2. KD树搜索过程(文字示意图)

假设我们要找点A(6,3,3)的最近邻:

1. 从根节点(7,2,3)开始,x=6<7 → 进入左子树 2. 在(5,4,2)节点,y=3<4 → 进入左子树 3. 到达叶子节点(2,3,1),计算距离:√[(6-2)²+(3-3)²+(3-1)²] = √20 ≈ 4.47 4. 回溯到(5,4,2)节点,计算距离:√[(6-5)²+(3-4)²+(3-2)²] = √3 ≈ 1.73 5. 回溯到根节点(7,2,3),计算距离:√[(6-7)²+(3-2)²+(3-3)²] = √2 ≈ 1.41 6. 检查(7,2,3)的右子树,确认(7,2,3)比(5,4,2)更近 7. 最终结果:点A(6,3,3)的最近邻是(7,2,3)

为什么KD树这么厉害?3个核心优势

  1. 快如闪电:不用检查所有点,时间复杂度从O(n)降到O(log n)

    • 比如:100万点,直接找要100万次比较,KD树可能只需要20次左右
  2. 空间感知:像有地图一样知道"哪里可能有目标"

    • 就像知道"电影院在商场的3楼",不用一层层找
  3. 灵活多用

    • 最近邻搜索:找离你最近的咖啡店
    • 半径搜索:找500米内的餐厅
    • K近邻搜索:找离你最近的5家餐厅

实际应用场景:从手机到自动驾驶

  1. 手机AR:你用手机AR看虚拟宠物,KD树帮你快速判断宠物在哪个位置

    • “这个点离摄像头最近,可以显示虚拟宠物”
  2. 自动驾驶:汽车扫描周围环境,KD树快速找到障碍物

    • “前面30米有个人,需要减速”
  3. 3D建模:扫描一个雕像,KD树帮你把点云拼成完整模型

    • “这个点和那个点距离很近,可以连接起来”

一句话总结

KD树就像是在3D点云中"画了一张智能地图",通过交替切分空间,把点云数据组织成树形结构,让你能像在超市找商品一样,快速找到目标点附近的点,而不是大海捞针。

下次看到"KD树",你就知道它是在3D空间里"画地图"的高手啦!😊

小贴士:在实际应用中(如PCL库),我们不需要手动构建KD树,只需调用现成的API,就像这样:

pcl::KdTreeFLANN<pcl::PointXYZI>::Ptrkdtree(newpcl::KdTreeFLANN<pcl::PointXYZI>());kdtree->setInputCloud(laserCloud);kdtree->nearestKSearch(searchPoint,K,pointIdxNKNSearch,pointNKNSquaredDistance);
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/13 17:29:08

Q1K3微型FPS游戏终极完整指南:从零开始构建你的3D射击世界

Q1K3微型FPS游戏终极完整指南&#xff1a;从零开始构建你的3D射击世界 【免费下载链接】q1k3 A tiny FPS for js13k 项目地址: https://gitcode.com/gh_mirrors/q1/q1k3 想要在13KB的限制内打造一个功能完整的3D射击游戏吗&#xff1f;Q1K3项目展示了如何在极小的文件体…

作者头像 李华
网站建设 2026/5/13 4:05:33

DeepFM终极指南:5步打造高精度CTR预测推荐系统

DeepFM终极指南&#xff1a;5步打造高精度CTR预测推荐系统 【免费下载链接】d2l-en d2l-ai/d2l-en: 是一个基于 Python 的深度学习教程&#xff0c;它使用了 SQLite 数据库存储数据。适合用于学习深度学习&#xff0c;特别是对于需要使用 Python 和 SQLite 数据库的场景。特点是…

作者头像 李华
网站建设 2026/5/11 21:50:11

软件工程导论实验报告——成绩管理系统(黑龙江大学)

面向对象分析与设计实验一 软件需求分析1.1 业务需求描述本系统主要包括系统管理员、教师、学生三种类型用户。学生可以查看个人成绩&#xff0c;查询学分和挂科数目以及学业预警。教师可以添加学生成绩&#xff0c;删除学生成绩&#xff0c;修改学生成绩&#xff0c;查看学生成…

作者头像 李华
网站建设 2026/5/12 7:39:59

打开 Windows 环境变量设置界面的6种方式

以下是打开 Windows 环境变量设置界面的 6 种常用方法&#xff0c;从最快捷到最直接&#xff0c;您可以根据使用习惯选择。 方法 1&#xff1a;通过任务栏搜索&#xff08;最推荐&#xff0c;Win10/11 通用&#xff09; 操作&#xff1a; 点击任务栏上的 搜索图标 或按快捷键…

作者头像 李华
网站建设 2026/5/11 7:02:52

复变函数:用复数求解实变积分问题

目录 一、上下无穷型积分&#xff08;实轴无奇点&#xff09; 二、主值积分&#xff08;实轴有奇点的上下无穷型积分&#xff09; 三、约当引理 四、含三角函数的无穷积分 五、三角函数型积分&#xff08;在[0,2π]上积分&#xff0c;不再是无穷积分&#xff09; 在工科实…

作者头像 李华