Open3D 点云的ISS关键点提取

目录

一、概述

1.1原理

1.2应用场景

1.3算法实现步骤

二、代码实现

2.1 完整代码

2.2关键函数

2.3关键点可视化

三、实现效果

3.1原始点云

3.2提取后点云


一、概述

1.1原理

        ISS(Intrinsic Shape Signatures)关键点提取是一种常用于三维点云的特征提取方法。其主要目的是在点云中找到具有显著几何特征的点,这些点在不同的点云扫描中具有鲁棒性和稳定性。

ISS关键点提取基于以下两个主要思想:

  1. 局部特征分析:在点云的局部区域内计算几何特征,选择在局部范围内具有显著几何变化的点。
  2. 尺度空间理论:通过分析不同尺度下的几何特征,选择具有稳定性的点。

具体来说,ISS关键点提取算法利用点云中每个点的局部邻域的协方差矩阵来分析局部几何结构。协方差矩阵的特征值可以揭示局部几何形状的显著性。通过筛选出特征值之间具有显著差异的点,ISS算法能够识别出关键点。

1.2应用场景

ISS关键点提取在许多三维点云处理应用中具有重要作用,主要应用场景包括:

  1. 三维物体识别与匹配:通过提取关键点并进行描述符匹配,可以实现三维物体的识别与匹配。
  2. SLAM(同步定位与地图构建):在SLAM系统中,关键点提取用于构建地图和进行定位,提供稳定的特征点以进行配准。
  3. 三维重建:在三维重建过程中,关键点提取用于对齐不同视角的点云数据,从而生成高质量的三维模型。
  4. 机器人导航:在机器人导航中,关键点提取用于环境感知和路径规划,帮助机器人理解和探索环境。
  5. 医学影像分析:在医学影像处理中,关键点提取用于分析和比较不同的三维扫描数据,如CT或MRI扫描结果。

1.3算法实现步骤

ISS关键点提取算法的主要步骤如下:

  1. 计算局部协方差矩阵:对于每个点,计算其局部邻域的协方差矩阵。
  2. 计算协方差矩阵的特征值:对协方差矩阵进行特征值分解,获得三个特征值(通常标记为 λ1, λ2, λ3)。
  3. 特征值筛选:根据特征值之间的关系,筛选出具有显著几何特征的点。一般通过设置阈值来筛选特征值之间差异显著的点。
  4. 尺度分析:在不同的尺度下重复上述过程,选择在多个尺度下具有稳定性的点。
  5. 去冗余:通过非最大抑制(NMS,Non-Maximum Suppression)去除冗余的关键点,保留最显著的点。

二、代码实现

2.1 完整代码

# 将提取的特征点变大 便于区分
def keypoints_to_spheres(keypoints):spheres = o3d.geometry.TriangleMesh()for keypoint in keypoints.points:sphere = o3d.geometry.TriangleMesh.create_sphere(radius=1)sphere.translate(keypoint)spheres += spherespheres.paint_uniform_color([1.0, 0.0, 0.0])# sphere.translate((1,0,0))return spherespcd = o3d.io.read_point_cloud("gargo50K.pcd")
print(pcd)
tic = time.time()
# --------------------ISS关键点提取的相关参数---------------------
keypoints = o3d.geometry.keypoint.compute_iss_keypoints(pcd,salient_radius=5,non_max_radius=5,gamma_21=0.5,gamma_32=0.5)
toc = 1000 * (time.time() - tic)
print("ISS Computation took {:.0f} [ms]".format(toc))
print("Extract",keypoints)
pcd.paint_uniform_color([0.0, 1.0, 0.0])o3d.visualization.draw_geometries([keypoints_to_spheres(keypoints), pcd],width=800,height=800)

2.2关键函数

keypoints = o3d.geometry.keypoint.compute_iss_keypoints(pcd,salient_radius=5,non_max_radius=5,gamma_21=0.5,gamma_32=0.5)
  • salient_radius 和 non_max_radius:这两个参数用于定义用于计算曲率和局部表面变化的邻域大小。较大的值可以捕捉更大范围内的局部几何信息,但也可能导致关键点的数量增加。
  • gamma_21 和 gamma_32:这两个参数是 ISS 算法中用来控制曲率比率阈值的参数。它们影响关键点的选择,较小的值可以产生更多但可能更松散的关键点集合,而较大的值则会限制关键点的数量和密度。

2.3关键点可视化

        函数 keypoints_to_spheres 的目的是将一组关键点(假设为 Open3D 中的 PointCloud 对象)转换成一组球体,每个球体都表示一个关键点。这些球体会被放置在对应关键点的位置,并且统一涂成红色,最后返回一个包含所有球体的TriangleMesh 对象。

        keypoints_to_spheres 函数会将 PointCloud 中的每个关键点转换成一个球体,并返回一个包含所有球体的 TriangleMesh 对象。然后可以使用 Open3D 的可视化工具将这些球体显示出来。

# 将提取的特征点变大 便于区分
def keypoints_to_spheres(keypoints):spheres = o3d.geometry.TriangleMesh()for keypoint in keypoints.points:sphere = o3d.geometry.TriangleMesh.create_sphere(radius=1)sphere.translate(keypoint)spheres += spherespheres.paint_uniform_color([1.0, 0.0, 0.0])# sphere.translate((1,0,0))return spheres

三、实现效果

3.1原始点云

3.2提取后点云

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

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

相关文章

【LLM-多模态】高效多模态大型语言模型综述

一、结论写在前面 模型规模的庞大及训练和推理成本的高昂,限制了MLLMs在学术界和工业界的广泛应用。因此,研究高效轻量级的MLLMs具有巨大潜力,特别是在边缘计算场景中。 论文深入探讨了高效MLLM文献的领域,提供了一个全面的视角…

Win10可用的VC6.0绿色版及辅助插件assist_X

VC6.0,作为微软的经典开发工具,承载着无数开发者的青春与回忆。它曾是Windows平台上软件开发的重要基石,为开发者们提供了稳定且强大的编程环境,尤其是其MFC(Microsoft Foundation Classes)库,为…

计算机网络:408考研|湖科大教书匠|原理参考系统I|学习笔记

系列目录 计算机网络总纲领 计算机网络特殊考点 目录 系列目录更新日志数据链路层(Data Link Layer)一、基本概念二、三个重要问题三、 🌟点对点协议(PPP, Point-to-Point Protocol)四、 以太网五、802.11 无线局域网(简称Wi-Fi) 物理层(Physical Layer)一、传输方…

SSM宠物领养系统-计算机毕业设计源码08465

目 录 摘要 1 绪论 1.1课题背景及意义 1.2研究现状 1.3ssm框架介绍 1.3论文结构与章节安排 2 宠物领养系统系统分析 2.1 可行性分析 2.2 系统流程分析 2.2.1 数据流程 3.3.2 业务流程 2.3 系统功能分析 2.3.1 功能性分析 2.3.2 非功能性分析 2.4 系统用例分析 …

uni-push(2.0)常见问题,Android平台

将常用的网址一定要收藏在标签栏中,方便后期找,不然后期会很生气。 草料二维码,这个在线工具可以将打包生成的apk文件生成二维码,供测试人员测试。生成的apk只有五次下载机会,可点击链接后的一键上传,这样…

数据资产管理的艺术之道:深入探索如何在数据价值的最大化、个人隐私的严密保护以及企业持续发展的战略需求之间找到微妙的平衡

在数字化浪潮席卷全球的今天,数据已成为企业最宝贵的资产之一。从市场营销到产品研发,从客户服务到运营管理,数据无处不在,为企业提供了前所未有的洞察力和竞争力。然而,随着数据量的激增和数据类型的多样化&#xff0…

【Linux网络(一)初识计算机网络】

一、网络发展 1.发展背景 2.发展类型 二、网络协议 1.认识协议 2.协议分层 3.OSI七层模型 4.TCP/IP协议 三、网络传输 1.协议报头 2.局域网内的两台主机通信 3.跨网络的两台主机通信 四、网络地址 1.IP地址 2.MAC地址 一、网络发展 1.发展背景 计算机网络的发展…

500万!2024年东西湖区促进工业园区转型升级改造奖励政策申报条件、流程指南

2024年东西湖区促进工业园区转型升级改造奖励政策申报条件、流程指南如下,东西湖区的企业单位可以了解一下 一、总体要求和基本原则 以“创新、协调、绿色、开放、共享”新发展理念为指引,统筹落实产业高质量发展的总体要求,以“亩均论英雄…

七天速通javaSE:第三天 程序控制结构:顺序、选择、循环

文章目录 前言一、Scanner类1. hasNext()和hasNextLine()2.next()和nextLine()3. Scanner的其他用法 二、顺序结构三、选择结构1. if单选择结构2. if-else双选择结构3. if-else if多选择结构4. switch选择结构 四、循环结构1. while循环2.do while循环3. for循环(常…

表单(forms)

自学python如何成为大佬(目录):https://blog.csdn.net/weixin_67859959/article/details/139049996?spm1001.2014.3001.5501 在app1文件夹下创建一个forms.py文件,添加如下类代码: from django import forms class PersonForm(forms.Form): first_na…

NULL和nullptr的区别以及为什么要引入nullptr

在 C 中,NULL 和 nullptr 都表示空指针,但它们有一些关键的区别。nullptr 是 C11 引入的,目的是解决 NULL 存在的一些问题。 NULL 和 nullptr 的区别 1. 类型 NULL: 通常被定义为 0 或 ((void*)0),具体定义取决于编译器和标准库…

C语言·动态内存管理

1. 为什么要有动态内存管理? 例1: //固定的向内存申请4个字节 int a 10;//申请连续的一块空间 int arr[10]; 这些数据一旦声明定义之后就会在内存中有一块空间,这些空间都是固定的,为了让内存使用更加灵活,这时我们…

MySQL中存储过程和函数的使用及异同

MySQL中的存储过程(Stored Procedure)和函数(Stored Function)都是预编译的SQL语句集合,用于执行特定任务,以提高代码重用性、减少网络通信量并可能提升性能。尽管它们有相似之处,但也存在一些关…

Debezium 同步 MySQL 实时数据并解决数据重复消费问题

我们使用 Debezium 实时同步一个 MySQL 的数据到另一个 MySQL,代码网上基本都有,都是在引入 debezium-api,debezium-embedded 后写 Java 代码,做好了基本配置后启动程序,Debezium 会自动读取 MySQL 的实时 binlog&…

断言提供了哪些方法

Java中的断言机制主要用于开发和测试阶段,以确保代码符合预期的行为。 除了assert关键字,Java标准库中的java.util.Objects类提供了几个实用方法,可以辅助实现更复杂的断言逻辑: Objects.requireNonNull(Object obj, String mess…

【Python机器学习】聚类算法简述

聚类的应用和评估时一个非常定性的过程,通常在数据分析的探索阶段很有帮助。 主要有三种聚类算法:k均值、DBSCAN、凝聚聚类。 这三种算法都可以控制聚类的粒度:k均值和凝聚聚类允许指定想要的簇的数量,而DBSCAN允许你用eps参数定…

SQLAlchemy:原理与使用详解

文章目录 引言SQLAlchemy的原理1. 对象关系映射(ORM)2. 引擎、会话和元数据3. 查询构造 SQLAlchemy的使用1. 安装SQLAlchemy2. 创建数据库连接和引擎3. 定义模型4. 创建表5. 操作数据库6. 关闭会话 结论 引言 在Python编程环境中,数据库操作…

【复旦邱锡鹏教授《神经网络与深度学习公开课》笔记】卷积

卷积经常用在信号处理中,用于计算信号的延迟累积。假设一个信号发射器每个时刻 t t t产生一个信号 x t x_t xt​,其信息的衰减率为 w k w_k wk​,即在 k − 1 k-1 k−1个时间步长后,信息为原来的 w k w_k wk​倍,时刻 …

SpringBoot开启事务日志

一般框架开启日志的方式: 开启某个包下的日志就写该包路径,开启某个类下的日志就写该类路径。

【数据结构】栈的定义与实现(附完整运行代码)

目录 一、栈的定义 二、顺序栈 链栈比较 三、栈的实现(顺序栈) 3.1 ❥ 定义栈结构 3.2 ❥ 初始化 3.3 ❥ 销毁 3.4 ❥ 插入(入栈) 3.5 ❥ 删除 (出栈) 3.6 ❥ 获取栈顶元素 3.7 ❥ 判空 3.8 ❥…