动态增删kdtree(ikdtree)主要思路

news2024/10/5 12:49:27

ikdtree本质上也是一种kdtree,基本的构造方法和kdtree是一样的,本文主要记录两者不一样的地方,以港大MaRS实验室最新开源的增量式 kd-tree(https://github.com/hku-mars/ikd-Tree)里面的一些代码作为示范。

以下是ikdtree结构体包括的基本变量,在港大开源的代码中结构变量是远远多于这里的,主要是为了利用其他方面(例如多线程)对树进一步优化加速。

{

     // 寻常kdtree也有的:
        uint8_t division_axis;  //以哪一个轴(x,y,z)作为的切分平面法线

        KD_TREE_NODE *left_son_ptr = nullptr; //左孩子节点
        KD_TREE_NODE *right_son_ptr = nullptr;//右孩子节点

        float node_range_x[2], node_range_y[2], node_range_z[2];   //AABB包围盒

 

    // 以下主要是用于增删的变量:

       PointType point; //点坐标
        int TreeSize = 1; //包括它本身和它左右孩子的总数量
        int invalid_point_num = 0; //包括自己在内已经被标记删除点的数量
        bool point_deleted = false; //该节点是否被标记删除
        KD_TREE_NODE *father_ptr = nullptr; //它的父亲节点

}

首先 说一下这里的点坐标,虽然有些kdtree的写法上也在内部节点上保存了点坐标,但更通常的做法是仅在叶子节点上有存储,而在ikdtree中,这个变量内部节点则必须存在,这在动态点插入的时候有很大的作用。

ikdtree节点的删除操作采用的是一种延迟删除操作的做法,这种做法其实并不陌生,c++ 标准库中remove就是这种策略,即仅对节点做删除标记,而不立即更新删除树,在结构体中point_deleted就是起到这个作用,标记完后,AABB盒是要立即更新的,但是要排除已经标记删除的数据。

ikdtree的插入操作是直接将节点插入在树的末尾,当然这也是有规则的,在港大开源的代码中,插入节点满足大于左节点(这里点坐标就有了用处),不满足则直接遍历右节点从而放在右节点末端,全部放在右节点末端是为了人为破坏树的平衡性,这是后面判断树更新的一个重要依据。同删除一样,插入完毕后,AABB盒要立即更新。

6521c3261f704ad691ae02e878afe354.jpeg

 上述做完之后,可以认为已经动态改变了,但是也可以看见,此时的删除和插入操作其实已经破坏了kdtree的特性,例如删除操作破坏了平衡特性,增加了很多无效的节点,增加了遍历,插入操作则破坏了树平衡性和有序性两个特性(这里注明一下,有序性的破坏并不会影响结果,这里让我迷糊了很久,因为寻找最近点即使有序的二叉树仅通过包围盒也是无法排除另一个孩子树的)。在破坏较小时,相比于重新建立树的效率相比,些许的效率损失可以接受,但是当变化太大后,这个tree结构也就几乎没有了加速的效果。因此在ikdtree中,在认为已经破坏过大时,必须更新树结构。ikdtree中提出了两个依据来判断是否树已经破坏过大:

一是被标记删除的个数占整个节点数量的比例,港大源代码中默认是要小于0.5,二是不平衡性,即是单个孩子节点数量占整个节点数量的比例,港大源代码中默认为在0.3~0.7之间为合理的。

当任何一个依据不满足时,树就要立即更新。

e8cb5be632954f699a91c0baf7549908.jpeg

在树更新的过程中,也不是整个树都要更新,仅仅只是不满足两个依据的子树进行自我更新,进一步优化了效率,示例如下图。这里结构体中的父亲节点就有了可用之地。

7726d951aeef47a38fbd00dbeb8ad777.png

d9ac3feff423429e97572874f5641eb1.jpeg 

 

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Linux精讲系列】——yum软件包管理

​作者主页 📚lovewold少个r博客主页 ⚠️本文重点:Linux系统软件包管理工具yum讲解 😄每日一言:踏向彼岸的每一步,都是到达彼岸本身。 目录 前言 Linux系统下的软件下载方式 yum 查看软件包 如何安装软件 如何卸…

业务连续性和恢复性计划:保障企业IT业务的可靠性

第一章:引言 在当今数字化时代,企业对信息技术的依赖愈发显著,IT系统的稳定性和可用性变得至关重要。无论是自然灾害、硬件故障还是网络攻击,都可能导致业务中断,从而带来严重的经济损失和声誉损害。为了保障企业IT业…

UI自动化测试工具推荐

UI自动化测试已经成为现代软件开发过程中不可或缺的一部分。它能够提供诸多优势,包括提高测试效率、减少人力成本、提升软件质量等。同时,可视化工具为UI自动化测试带来了更多便利和灵活性。然而,可视化工具也存在一些潜在的劣势。本文将探讨…

【电路笔记】-波特图(Bode Diagrams)

波特图(Bode Diagrams) 文章目录 波特图(Bode Diagrams)1、概述2、定义3、波特图的呈现4、常见的波特图4.1 一阶滤波器4.2 二阶滤波器 5、总结 1、概述 上世纪30年代末,一位名叫 Hendrick Wade Bode 的美国工程师设计了一个著名的表示法来研究频域中的交流电路。 这…

stable diffusion简介和原理

Stable Diffusion中文的意思是稳定扩散,本质上是基于AI的图像扩散生成模型。 Stable Diffusion是一个引人注目的深度学习模型,它使用潜在扩散过程来生成图像,允许模型在生成图像时考虑到文本的描述。这个模型的出现引起了广泛的关注和讨论&am…

Python 算法高级篇:回溯算法的优化与剪枝技巧

Python 算法高级篇:回溯算法的优化与剪枝技巧 引言 1. 什么是回溯算法?2. 回溯算法的优化与剪枝技巧2.1 剪枝技巧2.1.1 可行性剪枝2.1.2 最优性剪枝 2.2 优化方法 2.2.1 记忆化搜索2.2.2 双向搜索 3. 代码示例3.1 旅行推销员问题 4. 总结 引言 回溯算法…

Windows下如何编译FFmpeg

ffmpeg一般在linux环境中使用,但是我们目前很多的开发工具是windows,为了方便在windows下调试和使用ffmpeg,我们需要再windows下面编译和使用ffpeg,本文只讲述windows下如何编译ffmpeg的内容。   windows下编译ffmpeg有很多的方…

「Dr. Bomkus 的试炼」——最详尽的通关资讯!

🧪 Dr. Bomkus 的试炼:新的冒险来临 天才科学家Dr. Bomkus一直在不知疲倦地打造他的最新作品。但是遇到了一些问题!现在,他需要你的帮助。 为了找到真正的有价值之人,Dr. Bomkus准备了六场试炼。这一系列令人激动的挑战…

VR全景餐厅,为餐饮老板开启了新纪元

在近两年的“元宇宙”概念的催生下,VR全景技术逐渐渗透到我们生活的方方面面,从舌尖到指尖、从田间到车间、从衣食住行到娱乐消费等,越来越多的行业、领域开始引入VR全景了,并在各自的垂直领域开拓了VR全景新时代。 而一直以来&am…

VBA技术资料MF73:将Logo添加到页眉侧

我给VBA的定义:VBA是个人小型自动化处理的有效工具。利用好了,可以大大提高自己的工作效率,而且可以提高数据的准确度。我的教程一共九套,分为初级、中级、高级三大部分。是对VBA的系统讲解,从简单的入门,到…

SENet 学习

ILSVRC 是一个比赛,全称是ImageNet Large-Scale Visual Recognition Challenge,平常说的ImageNet比赛指的是这个比赛。 使用的数据集是ImageNet数据集的一个子集,一般说的ImageNet(数据集)实际上指的是ImageNet的这个子…

解决javascript报错:SyntaxError: Invalid Unicode escape sequence

在处理cookie时报这个错: 网上搜了一圈都说是反斜杠问题,要把\替换成/ 但是试了网上的replace替换: replace(/\\/g, /) 结果没有用!!! 然后我干脆直接做了一个最简单字符串赋值,再打印出来。…

GZ035 5G组网与运维赛题第2套

2023年全国职业院校技能大赛 GZ035 5G组网与运维赛项(高职组) 赛题第2套 一、竞赛须知 1.竞赛内容分布 竞赛模块1--5G公共网络规划部署与开通(35分) 子任务1:5G公共网络部署与调试(15分) 子任务2:5G室内与室外站点建设(20分) 竞赛模块2--5G公共网络运维与优化(…

ROS学习笔记——配置环境变量

重点解决:避免每次都source ros2环境,每次都要设置ros_domain_id等等设置 Background ROS 2 relies on the notion of combining workspaces using the shell environment. ros2 依赖于“组合工作区”这个改变,使用shell 环境来实现 …

中央设备状态监控系统CMS如何帮助半导体晶圆厂提高产品良率

中央设备状态监控系统(CMS)在半导体晶圆厂中扮演着关键角色,帮助企业提高产品的良率。本文将介绍CMS是什么、当前半导体晶圆厂产品良率面临的挑战,并重点探讨CMS如何通过实时数据监控、故障预测和预警、以及统计分析和过程改进等方…

Linux之VM、WindowsServer安装及开发环境配置

目录 前言 一、操作系统简介 1. 基本概述 1.2 常见的操作系统 1.3 个人版本与服务器版本的区别 1.4 Linux的各个版本 Debian Ubuntu Redhat Fedora centos 二、安装并配置VMWare虚拟机 1. 安装 2. 激活VM虚拟机软件 3. 使用注意事项 3.1 注意点一:配置…

设计大师都在用!电商设计素材网站大公开

双十一即将到来,想必各电商平台的设计师早已开启电商设计项目。找到合适的电商设计模板是电商设计成功的关键因素。高质量的电商设计模板素材不仅能够提升网站的吸引力,还能提升用户体验,从而增加商品的交易率。 Pixso资源社区 在寻找电商设计…

【LeetCode】102. 二叉树的层序遍历

题目链接 文章目录 Python3方法一: 广度优先搜索 (BFS) ⟮ O ( n ) ⟯ \lgroup O(n) \rgroup ⟮O(n)⟯方法二: 深度优先搜索 (DFS) ⟮ O ( n ) ⟯ \lgroup O(n) \rgroup ⟮O(n)⟯ C方法一: 广度优先搜索 (BFS) ⟮ O ( n ) ⟯ \lgroup O(n…

arch linux 安装 vsftpd 配置虚拟用户

后面操作会直接基于 yay 操作 自行查找如何安装 yay 公司经常会用到 ftp 服务 不想用 apache 的 ftp server 所以自己在小机器上撞了 arch linux 用来安装软件 跑程序等。 1. 安装 vsftpd yay vsftpd --noconfirm选择 1 安装 输入密码 2. 安装 pam_pwdfile 安装 pam_pwdf…

走近Nexstar Digital,看美国百家电视台内容管理的齿轮如何运转?

美国五大电视网之一的CW电视台,是《邪恶力量》《吸血鬼日记》等热播剧的产地,最终在2022年被Nexstar收入囊中。 Nexstar Media Group是全球领先的多元化媒体公司之一,也是美国最大的地方广播电视集团之一,活跃于美国116个市场&am…