『OPEN3D』1.8 点云的配准理论
点云的配准是将不同的3D点云对齐成一个完成的点云模型;配准的目标是找到两帧点云之间的相对旋转(rotation)与平移(translation),使得两份点云中有重叠的区域能够完好拼接。
点云配准示例图(来自PCL)

上图为初始的5份点云数据,需要将着几份点云数据拼接成如下图中完整的模型

点云动态配准示例

常见的点云配准方式主要包含ICP配准以及NDT配准以及他们的配准,当然还包括神经网络的点云配准方式。
1、点云配准理论
点云配准需要找到两份点云数据之间点的对应估计,也就是找到两份点云中重叠的部分才可以进行配准,这类配准,对于有确定对应点的配准拥有闭式解(closed form solution)不需要迭代求解即可获取最优值。
对应点的寻找方式:
1 若为深度相机,则可以借助图像信息来寻找对应的匹配点并投影回3d空间
2 若为两帧点云信息,则可以借助点云特征点来进行确立
不过上诉方法都会出现误匹配,一般会借助RANSAC(随机采样一致性)来得到更为robust的估计。
1 ICP主要为point2point ICP和point2plane两种ICP方式
ICP配准点云时需要有较为准确的初始位姿后再使用该方法进行精配准;ICP的点云配准大体步骤分为如下几步:
1 点的匹配(可以从图像中来或者点云中来)
1.1 在两帧点云中找到对应的关键点,点云中的关键点一般为特定的几何结构,比如书本的边角,与图像类似;点云中的关键点包括NARF;SIFT;FAST;当然也可以不适用关键点;使用每一个点或者点云中的一部分点来进行配准;不过那样的话会导致计算量过大。
1.2 特征的描述子;与图像类似,再找到点云的关键点后,需要提取该关键点的描述子信息;通过组合该结构的信息来生成对应的向量用于比对;点云的中描述子包括NARF;FPFH;BRIEF;SIFT等。
2 匹配点估计;给定两帧点云的特征向量集合;通过关键点与描述子来找到重叠区域中相互对应的关键点:对于关键点或特征的匹配,可以使用暴力搜索;kd-tree(FLANN)等方式来进行匹配
3 匹配点对估计;类似与图像中关键点匹配;点云中的关键点匹配也存在许多误匹配;误匹配会影响最终的配准结果;因此此处可以使用ransac或者根据匹配点对的百分位进行截取等方式来进行优化;如果一帧中的某个关键点与另一帧中的多个关键点匹配;则会取最小距离来确定匹配点
4 变换矩阵计算;再得到准确的相互匹配的点云后;则可以计算变换矩阵;
其中point2point的评估误差为

point2plane的评估误差为(其中np为点P的法线信息)

估计两个点集的R和t可以使用使用SVD或者非线性优化求解;
1 SVD方法
给定两对匹配点的点集和
,对其中第i对匹配点的误差项为:
因此可以对所有点构建最小二乘问题,求得使误差平方和达到极小的R和t:
分别定义两组点的质心为(此处使用不带下标的项来代表质心):
在误差函数中进行展开

展开后最后一项元素求和为0(所有元素相加减去n个
的质心
为0),因此优化的结果仅与前两项相关,即
上式中,只有左边和旋转矩阵R相关,右侧同时R与t。因此只要求得R后令右式为0即可求出t。
ICP的SVD方法流程如下
1、计算两组匹配点的质心与
, 然后将每个点减去质心得到去质心的坐标:
2、根据上述阐述的优化,计算旋转矩阵:
3、根据计算得到的旋转矩阵计算平移向量t
因此,按照上面的步骤,要先求取两组点集之间的旋转矩阵,所以下面说重点一下R的计算:
其中第一项与R无关;第二项
中因为R为正交矩阵因此
,也与R无关;只有最后一项的
与R有关,因此有如下推导:
注: 其中为trace(迹),有
然后可以使用SVD分解得出最优的旋转矩阵R。
可知W是一个n*n的矩阵,n为点集的维度,若是点云数据则n=3则W是3*3的矩阵,
若此时W是可逆矩阵,则可以直接通过公式获得最优的旋转矩阵
但考虑到所有情况,直接对W进行SVD分解也是可以的:
其中为奇异值组成的对角矩阵,对角线元素从大到小排列,UV则为正交矩阵;当W满秩时,R为
若R的行列式为负数,则去-R为最优数值。
对这块刚兴趣的同学可以参考Kabsch算法的实现
https://en.wikipedia.org/wiki/Kabsch_algorithm
https://en.wikipedia.org/wiki/Kabsch_algorithm
2 非线性优化
2 open3d中使用ICP
更新中
相关文章:
『OPEN3D』1.8 点云的配准理论
点云的配准是将不同的3D点云对齐成一个完成的点云模型;配准的目标是找到两帧点云之间的相对旋转(rotation)与平移(translation),使得两份点云中有重叠的区域能够完好拼接。 点云配准示例图(来自…...
Python数据结构
目录 5.1. 列表详解 5.1.1. 用列表实现堆栈 5.1.2. 用列表实现队列 5.1.3. 列表推导式 5.1.4. 嵌套的列表推导式 5.2. del 语句 5.3. 元组和序列 5.4. 集合 5.5. 字典 5.6. 循环的技巧 5.7. 深入条件控制 5.8. 序列和其他类型的比较 本章深入讲解之前学过的一些内容…...
突发!新华三总裁《致全体员工的一封信》,中高层全面降薪10%-20%!
* 你好,我是前端队长,在职场,玩副业,文末有福利! 精彩回顾:进了央企,拿了户口,却感觉被困住了。 11月23号,某社交平台爆出了新华三总裁于英涛的《致全体员工的一封信》&a…...
QIIME 2介绍
QIIME 2(Quantitative Insights Into Microbial Ecology 2)是一个用于分析和解释微生物组数据的开源生物信息学工具。它是QIIME的第二个版本,经过重新设计以提高灵活性、可扩展性和可重复性。 1. 关于QIIME 2的一些重要特征和概念࿱…...
Spring Cloud Gateway 的简单介绍和基本使用
前言 本文主要对Spring Cloud Gateway进行简单的概念介绍,并通过多模块编程的方式进行一个简单的实操。 文章目录 前言1 什么是网关(概念)2 微服务中的网关2.1 问题12.2 问题2 3 网关作用4 Spring Cloud Gateway组成5 Spring Cloud Gateway基…...
Leaflet结合Echarts实现迁徙图
效果图如下: <!DOCTYPE html> <html><head><title>Leaflet结合Echarts4实现迁徙图</title><meta charset"utf-8" /><meta name"viewport" content"widthdevice-width, initial-scale1.0">…...
在mysql存储过程中间部分,使用游标遍历动态结果集(游标动态传参使用)
mysql游标动态传参实现(动态游标) 1.问题2.需求描述3.实现3.1.使用3.2.代码(直接看这都可以) 1.问题 众所周知,mysql存储过程功能是没有oracle的包功能强大的,但是在去O的趋势下,mysql存储过程的…...
全球SAR卫星大盘点与回波数据处理专栏目录
近年来,随着商业航天的蓬勃发展,商业SAR卫星星座成为美欧等主要航天国家的发展重点,目前已在全球范围内涌现出众多初创公司进军商业SAR领域,开始构建大规模商业微小SAR卫星星座,其所具有的创新服务能力将为传统的商业遥…...
C语言重点编程题——21-30
目录 21. 从键盘输入的10个整数中,找出第一个能被7整除的数。若找到,打印此数后退出循环;若未找到,打印"not exist" ★★★★22.有一个一维数组,内放10个学生成绩,写一个函数,求出平均分。 23.有N个学生,每个学生的信息包括学号、 性别、姓名、四门课的成绩…...
pip install 使用清华镜像源
pip install -i https://pypi.tuna.tsinghua.edu.cn/simple some-package 官方文档: pypi | 镜像站使用帮助 | 清华大学开源软件镜像站 | Tsinghua Open Source Mirror...
VBA技术资料MF86:将PPT文件批量另存为PDF文件
我给VBA的定义:VBA是个人小型自动化处理的有效工具。利用好了,可以大大提高自己的工作效率,而且可以提高数据的准确度。我的教程一共九套,分为初级、中级、高级三大部分。是对VBA的系统讲解,从简单的入门,到…...
taro h5 ios解决input不能自动获取焦点拉起键盘
描述:页面中有个按钮,点击跳转到第二个页面(有input),能直接获取焦点拉起键盘输入 安卓: 直接用focus() ios: focus无效,必须手动拉起 原理: 点击按钮的时候拉起一…...
「Docker」如何在苹果电脑上构建简单的Go云原生程序「MacOS」
介绍 使用Docker开发Golang云原生应用程序,使用Golang服务和Redis服务 注:写得很详细 为方便我的朋友可以看懂 环境部署 确保已经安装Go、docker等基础配置 官网下载链接直达:Docker官网下载 Go官网下载 操作步骤 第一步 创建一个…...
Vue环境的搭建
1.Vue开发的两种方式 (1)核心包传统开发模式 基于html/css/js文件,直接引入,开发Vue。 (2)工程化开发模式(更常用的一种): 主要是基于构建工具(例如,webp…...
在Spring Boot中实现单文件,多文件上传
这篇文章算是一篇水文,因为也没啥好讲的,在Spring Boot中,上传文件是我们常常做的,包括我们在实际开发过程中,我们也经常碰到与文件上传有关的功能,这也算是我们常用的一个功能了,毕竟作为开发者…...
如何在 Web 应用程序中查找端点?
如何在 Web 应用程序中查找端点? 这篇文章主要讲述了如何在网络应用中找到端点。以下是文章的主要要点: 端点是网络服务的访问地址,通过引用这个URL,客户可以访问服务提供的操作。端点提供了寻址Web服务端点所需的信息。 HTTP消息是服务器和客户端之间交换数据的方式,包…...
使用el-scrollbar实现定位滚动,以及el-scrollbar去掉横向滚动条
实现滚动 <el-scrollbar ref"scroll" style"height: 100%;">// ... </el-scrollbar>可以使用如下属性: 想要滚动到哪个指定位置,自己获取或计算 this.$refs[scroll].wrap.scrollTop 0 //想滚到哪个高度,…...
AOP + 自定义注解实现日志打印
1. 先定义个注解,让它作用于方法上 Target({ElementType.METHOD}) Retention(RetentionPolicy.RUNTIME) public interface Loggable {}2. 定义切面 Aspect Component Slf4j public class LogMethodCallAspect {Pointcut("annotation(com.wy.spring_demo.aop.…...
美团YOLOv6量化部署实战方案
文章目录 1. 背景和难点2. 量化方案实战2.1 重参数化优化器2.1.1 RepOpt2.1.2 RepOpt 版本的 PTQ2.1.3 RepOpt 版本的 QAT2.2 基于量化敏感度分析的部分量化2.3 基于通道蒸馏的量化感知训练2.3.1 通道蒸馏2.3.2 YOLOv6 量化感知蒸馏框架3. 部署时优化3.1 图优化3.1.1 性能分析3…...
hive杂谈
数据仓库是一个面向主题的、集成的、非易失的、随时间变化的,用来支持管理人员决策的数据集合,数据仓库中包含了粒度化的企业数据。 数据仓库的主要特征是:主题性、集成性、非易失性、时变性。 数据仓库的体系结构通常包含4个层次ÿ…...
终极图表绘制方案:drawio-libs免费图标库完整指南
终极图表绘制方案:drawio-libs免费图标库完整指南 【免费下载链接】drawio-libs Libraries for draw.io 项目地址: https://gitcode.com/gh_mirrors/dr/drawio-libs 还在为绘制专业图表而烦恼吗?drawio-libs正是你需要的解决方案。这个开源项目为…...
硬盘里那个仙剑的文件夹,你多久没打开过了?DOCKER部署DOS怀旧模拟器,带你秒回童年!
前言 大概每个 80 后、90 后玩家的硬盘深处,都有一个仙剑的文件夹。 我也不例外。当年第一次通关,在苏州城里听到《仙剑奇侠传》的音乐响起来,整个人愣在屏幕前——那时候还不懂什么叫叙事,什么叫情感冲击,只觉得李逍…...
SpringCloud微服务进阶-Nacos更加全能的注册中心劫
插件化架构 v3 版本最大的变化是引入了模块化插件系统。此前版本中集成在核心包里的原生功能,现在被拆分成独立的插件。 每个插件都是一个独立的 Composer 包,包含 Swift 和 Kotlin 代码、权限清单以及原生依赖。开发者只需安装实际用到的插件࿰…...
Zsh安全警报不用慌:3种方法彻底解决compinit目录权限问题
Zsh安全警报不用慌:3种方法彻底解决compinit目录权限问题 每次打开终端时看到那个恼人的"compinit: insecure directories"警告,确实让人头疼。作为Zsh用户,我们既想享受这个强大shell带来的便利,又不希望被安全警告打…...
Stable Diffusion 3.5问题解决:常见报错(如CUDA内存不足)快速排查指南
Stable Diffusion 3.5问题解决:常见报错(如CUDA内存不足)快速排查指南 你是否在使用Stable Diffusion 3.5时遇到过突然崩溃的情况?屏幕上跳出"CUDA out of memory"的红色警告,辛苦调整的参数和创意灵感瞬间…...
DAMOYOLO-S多场景落地:智能硬件产品出厂前目标检测功能自动化校验
DAMOYOLO-S多场景落地:智能硬件产品出厂前目标检测功能自动化校验 1. 引言:从质检痛点说起 想象一下这个场景:你是一家智能硬件公司的生产线负责人。每天,成千上万的摄像头、扫地机器人、智能门锁从流水线上下来。每个产品都内置…...
STM32F030K6T6 定时器触发ADC采样的DMA传输实战
1. 为什么需要定时器触发ADC采样? 在嵌入式开发中,ADC(模数转换器)采样是获取模拟信号的关键环节。传统的手动触发或查询式ADC采样存在两个明显痛点:一是需要CPU频繁介入,二是采样间隔难以精确控制。比如用…...
ESP32终极入门指南:5步完成Arduino开发环境搭建与WiFi连接
ESP32终极入门指南:5步完成Arduino开发环境搭建与WiFi连接 【免费下载链接】arduino-esp32 Arduino core for the ESP32 项目地址: https://gitcode.com/GitHub_Trending/ar/arduino-esp32 如果你正在寻找一个功能强大且易于上手的物联网开发平台,…...
手把手教你用Silvaco TCAD仿真SiC MOSFET:从工艺步骤到参数提取的保姆级指南
手把手教你用Silvaco TCAD仿真SiC MOSFET:从工艺步骤到参数提取的保姆级指南 在功率半导体领域,碳化硅(SiC)MOSFET凭借其优异的材料特性正逐步取代传统硅基器件。对于工程师和研究人员而言,掌握TCAD仿真工具已成为理解…...
Z-Image-GGUF助力游戏开发:快速生成概念原画与道具图标
Z-Image-GGUF助力游戏开发:快速生成概念原画与道具图标 做游戏,最让人头疼的环节之一,可能就是美术资源了。尤其是项目初期,策划脑子里天马行空的想法,要变成一张张看得见摸得着的概念图、道具图标,这个过…...
