使用迭代最近点 (ICP) 算法在 Open3D 中对齐点云

一、Open3D 简介及其功能

   Open3D 是一个现代库,它提供了用于处理 3D 数据的各种工具。在其功能中,它提供了高效的数据结构和算法来处理点云、网格等,使其成为在计算机视觉、机器人和图形领域工作的研究人员和从业人员的不错选择。Open3D 的特点之一是它实现了迭代最近点 (ICP) 算法,该算法用于模型对齐任务。

二、Open3D 和 ICP 入门

   迭代最近点 (ICP) 算法是用于对齐 3D 模型的基本技术。它的工作原理是迭代最小化两个点云或一个点云与 3D 模型之间的距离。该算法假设两个点云在不同的方向和/或位置表示相同的对象或场景。ICP 对于机器人和增强现实中的对象识别、定位和映射等任务特别有用。

   要在 Open3D 中使用 ICP,您首先需要安装库。您可以使用 pip 执行此操作:

pip install open3d

   Open3D 在其示例数据集中包含许多模型。安装后,我们可以导入 Open3D 并加载 Stanford Bunny 模型,这是一个用于测试 3D 算法的标准数据集:

import open3d as o3d 
# Load the Bunny mesh
bunny = o3d.data.BunnyMesh()
mesh = o3d.io.read_triangle_mesh(bunny.path)

   接下来,为了使 ICP 算法正常工作,有必要像这样计算顶点法线:

mesh.compute_vertex_normals()

   接下来,放下样本,这样我们就没有那么多点可以拟合了:

# Sample points from the mesh
pcd = mesh.sample_points_poisson_disk(number_of_points=1000)

   要在 Plotly 中将点云可视化为 3D 散点图,可以将 Open3D 点云转换为 NumPy 数组以进行 3D 绘图:

import plotly.graph_objects as go
import numpy as np# Convert Open3D point cloud to NumPy array
xyz = np.asarray(pcd.points)# Create a 3D scatter plot
scatter = go.Scatter3d(x=xyz[:, 0], y=xyz[:, 1], z=xyz[:, 2], mode='markers', marker=dict(size=1))
fig = go.Figure(data=[scatter])
fig.show()

斯坦福兔子点云
在这里插入图片描述

三、旋转模型并查找旋转矩阵

   为了演示 ICP,让我们创建一个 Bunny 模型的旋转版本,方法是将原始模型旋转 45 度,然后使用 ICP 找到原始模型和旋转模型之间的旋转矩阵:

# Apply an arbitrary rotation to the original point cloud
R = o3d.geometry.get_rotation_matrix_from_xyz((np.pi / 4, np.pi / 4, np.pi / 4))
rotated_pcd = pcd.rotate(R, center=(0, 0, 0))

查看旋转的兔子,确保一切正常:

# Convert Open3D point cloud to NumPy array
xyz_rot = np.asarray(rotated_pcd.points)# Create a 3D scatter plot
scatter = go.Scatter3d(x=xyz_rot[:, 0], y=xyz_rot[:, 1], z=xyz[:, 2], mode='markers', marker=dict(size=1.0))
fig = go.Figure(data=[scatter])
fig.show()

在这里插入图片描述
斯坦福兔子旋转 45 度

   现在,我们使用 ICP 来查找原始模型和旋转模型之间的转换矩阵。

# Use ICP to find the rotation
threshold = 0.02  # Distance threshold
trans_init = np.identity(4)  # Initial guess (identity matrix)
trans_init[:3, :3] = R  # We set the initial rotation to the known rotation
reg_p2p = o3d.pipelines.registration.registration_icp(source=rotated_pcd, target=pcd, max_correspondence_distance=threshold,init=trans_init
)# Extract the rotation matrix from the transformation matrix
estimated_rotation_matrix = reg_p2p.transformation[:3, :3]
rotation_matrix = reg_p2p.transformation[:3, :3]
print("Estimated rotation matrix:")
print(rotation_matrix)

   ​ICP发现的原始模型和旋转模型之间的旋转矩阵
在这里插入图片描述

四、验证旋转

   为了验证旋转,我们可以将估计旋转矩阵的逆函数应用于旋转模型,并将其与原始模型进行比较。通过取点之间的均方误差 (MSE),我们可以检查旋转的模型是否在指定的公差范围内恢复到其原始对齐方式:

# Extract the rotation matrix from the transformation matrix
estimated_rotation_matrix = reg_p2p.transformation[:3, :3]# Apply the inverse of the estimated rotation to the rotated point cloud
inverse_rotation_matrix = np.linalg.inv(estimated_rotation_matrix)
rotated_back_pcd = rotated_pcd.rotate(inverse_rotation_matrix, center=(0, 0, 0))# Compare the original point cloud to the one rotated back to its original state
# We can use the mean squared error (MSE) between corresponding points as a metric
original_points = np.asarray(pcd.points)
rotated_back_points = np.asarray(rotated_back_pcd.points)
mse = np.mean(np.linalg.norm(original_points - rotated_back_points, axis=1) ** 2)# Check if the MSE is below a certain tolerance
tolerance = 1e-6
if mse < tolerance:print(f"Test passed: MSE = {mse}")
else:print(f"Test failed: MSE = {mse}")

   假设一切顺利,您应该会看到测试通过的结果,表明点云已重新对齐。

在这里插入图片描述
   显示 ICP 算法的演示到此结束:

   1 在两个未对齐的模型之间查找旋转,以及
   2 使用这些结果将旋转的模型重新对齐回原始方向。

五、使用 ICP 的局限性

   虽然 ICP 是用于模型对齐的强大工具,但它也有其局限性:

  •    ICP 需要良好的初始猜测才能收敛到正确的解决方案,尤其是对于具有大旋转或平移的点云。
  •    该算法可能在对称或无特征的表面上遇到困难,在这些表面上建立正确的对应关系具有挑战性。
  •    异常值和噪声会显著影响 ICP 的性能,从而导致不正确的对齐方式。
  •    ICP 不处理点云之间的尺度差异,因为它假定点云已经处于相同的尺度。
       尽管存在这些局限性,但 ICP 仍然是 3D 数据处理中广泛使用的算法,Open3D 提供了一个用户友好的界面,可将 ICP 应用于各种对齐问题。通过仔细的预处理和参数调整,ICP 可以成为对齐 3D 模型的可靠解决方案。

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

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

相关文章

2024 年最新安装MAC-vue教学包括常见错误

花了一上午时间终于将 vue 的工程文件安装好了&#xff0c;本教材是傻瓜式操作&#xff0c;按着教程一步一步操作最后就可以看到页面了。 安装Node 1.在线地址&#xff1a; https://nodejs.org/en 2、点击 Download Node.js下载即可&#xff0c;下载完成后&#xff0c;傻瓜式的…

primeflex Display盒模型显示相关样式实战案例

01 Display盒子模式相关样式 基础样式 ClassPropertieshiddendisplay: none;blockdisplay: block;inlinedisplay: inline;inline-blockdisplay: inline-block;flexdisplay: flex;inline-flexdisplay: inline-flex; 样式说明&#xff1a; hidden&#xff1a;隐藏&#xff0c…

c# 学习教程

打印语句 折叠代码 变量 整形 浮点型 特殊类型

林业调查具体是做些什么?

林业调查是对森林资源进行系统的信息收集和处理的过程。 林业调查涵盖了对林木、林地以及林区内生长的动植物及其环境条件的全面评估&#xff0c;旨在及时掌握森林资源的数量、质量和生长消亡的动态规律。这种调查不仅关注森林本身&#xff0c;还包括与之相关的自然环境和经济…

企业级win10电脑下同时存在Python3.11.7Python3.6.6,其中Python3.6.6是后装的【过程与踩坑复盘】

背景&#xff1a; 需要迁移原始服务器的上的Python3.6.6Flask项目到一个新服务器上&#xff0c; 新服务器上本身存在一个Python3.11.7, 所以这涉及到了一个电脑需要装多个Python版本的问题 过程&#xff1a; 1-确定新电脑版本【比如是32还是64位】 前面开发人员存留了两个…

算法练习第26天|46.全排列、47全排列II

46.全排列 46. 全排列 - 力扣&#xff08;LeetCode&#xff09;https://leetcode.cn/problems/permutations/description/ 题目描述&#xff1a; 给定一个不含重复数字的数组 nums &#xff0c;返回其 所有可能的全排列 。你可以 按任意顺序 返回答案。 示例 1&#xff1a;…

STM32 | 超声波实战

​01、上节回顾 STM32 | HC-SR04 超声波测距模块 | DHT11数字温湿度传感器(第七天)STM32 | 数字温湿度传感器DHT11STM32 | HC-SR04 超声波测距模块STM32 | DHT11数字温湿度传感器实战02、超声波图示 03、超声波头文件 #ifndef __SR04_H#define __SR04_H​#include "stm…

在鸿蒙中身份校验的手势密码的实现

在harmony中它提供了默认的组件PatternLock()&#xff1b; 这个就能直接显示九宫格密码验证 并且他有两个主要的回调事件 .onDotConnect密码输入选中宫格圆点时触发该回调 .onPatternComplete&#xff1a;密码输入结束时触发该回调 //如代码实现 PatternLock().sideLength(32…

OceanBase 内存研究(OceanBase 3.2.4.5)

内存结构 从官网的结构图可以看出&#xff0c;一台observer可使用的总内存(memory_limit)包括 系统内存(system_memory) 和 租户内存(sys租户与普通租户) 系统内存 系统内存system_memory 属于 observer 的内部内存&#xff0c;允许其它租户共享使用该内存资源 (root10.0.0.…

vmware 正版免费下载

Broadcom 已经收购了 vmware 并且对普通用户提供免费服务. 那么我们怎么去获取这个玩意呢, 注册完之后打开就是这么个狗屎 , 根本不知道在哪里下载&#xff0c;注册的时候还不能用国内邮箱更是超级狗屎 转到 dashboard 搜索 workstation Pro你会搜索到这么一个奇怪的网址然后…

SSM与Mamba模型学习

transformer的缺陷 自注意力机制的计算范围只限于窗口内&#xff0c;不能直接处理窗口外的元素&#xff0c;不能照顾到整个序列。 由于计算复杂度随着窗口的长度呈几何平方式增长&#xff0c;所以不能一味地增加窗口长度来解决。 Transformer本质上是通过位置编码将序列数据空…

AI在线UI代码生成,不需要敲一行代码,聊聊天,上传图片,就能生成前端页面的开发神器

ioDraw的在线UI代码生成器是一款开发神器&#xff0c;它可以让您在无需编写一行代码的情况下创建前端页面。 主要优势&#xff1a; 1、极简操作&#xff1a;只需聊天或上传图片&#xff0c;即可生成响应式的Tailwind CSS代码。 2、节省时间&#xff1a;自动生成代码可以节省大…

微信小程序-页面配置

一、页面配置文件的作用 小程序中&#xff0c;每个页面都有自己的.json配置文件&#xff0c;用来对当前页面的窗口外观、页面效果等进行配置 二、页面配置和全局配置的关系 小程序中&#xff0c;app.json中的window节点&#xff0c;可以全局配置小程序中每个页面的窗口表现 …

FastDFS分布式文件系统——上传本地文件

目录 安装FastDFS FastDFS 使用Java客户端上传本地文件到FastDFS服务器上 pom.xml fastdfs_conf配置文件 FastDFS 测试 安装FastDFS 1、用FastDFS一步步搭建文件管理系统 - bojiangzhou - 博客园 (cnblogs.com)2、FastDFS文件上传功能封装 - 动力节点 (bjpowernode.com)…

Keras深度学习框架实战(2):估计模型训练所需的样本量

1、模型训练样本量评估概述 1.1 样本量评估的意义 预估模型需要的样本量对于机器学习项目的成功至关重要&#xff0c;以下是几个主要原因&#xff1a; 防止过拟合与欠拟合&#xff1a; 过拟合&#xff1a;当模型在训练数据上表现极好&#xff0c;但在未见过的测试数据上表现糟…

5步3分钟0基础搭建,轻松搭建《雾锁王国》私人服务器

继《幻兽帕鲁》游戏爆火之后&#xff0c;与它同类型的《雾锁王国》也是强力刷屏&#xff0c;不分伯仲&#xff0c;在 Steam 上的评分一直稳定在“特别好评”&#xff0c;让小伙伴们很“上头”。就在两者游戏玩家反响爆火的同时&#xff0c;官方服务器人数爆满&#xff0c;卡顿频…

C语言Linux进度条模拟

在Linux字符界面中&#xff0c;使用yum、apt下载东西时会有一个图形化的进度条&#xff0c;可以告诉我们任务的执行进度。 我们也可以通过C语言实现一个类似的进度条&#xff0c;并且可以做得更加美观。以后我们自己写的程序需要显示进度时就可以去调用我们自己实现的进度条。 …

【typescript/flatbuffer】在websocket中使用flatbuffer

目录 说在前面场景fbs服务器代码前端typescript代码问题 说在前面 操作系统&#xff1a;Windows11node版本&#xff1a;v18.19.0typescript flatbuffer版本&#xff1a;24.3.25 场景 服务器(本文为golanggin)与前端通信时使用flatbuffer进行序列化与反序列化通信协议为websock…

从0开始制作微信小程序

目录 前言 正文 需要事先准备的 需要事先掌握的 什么是uniapp 平台应用的分类方式 什么是TypeScript 创建项目 项目文件作用 源码地址 尾声 &#x1f52d; Hi,I’m Pleasure1234&#x1f331; I’m currently learning Vue.js,SpringBoot,Computer Security and so on.&#x1…