点集配准---迭代最近点算法ICP(Iterative Closest Point)

迭代最近点算法ICP(Iterative Closest Point)

一、算法流程:

在带匹配的目标点云P和源点云Q中,按照欧氏距离,找到对应的最邻近点pi∈目标点云P,qi∈目标点云Q。然后计算出最优匹配参数R和t,使得误差函数最小。误差函数为E(R,t)为:

https://www.bilibili.com/video/BV1ri421Z7i7/?spm_id_from=333.337.search-card.all.click\&vd_source=fa2de999698ac3d60b845e474ef6d191

二、公式推导:

步骤 1:计算点云质心,消除平移干扰

将两个点集都以质心点为坐标原点。

步骤 2:代入误差函数,分离旋转与平移

注意上图中第二项中仅与平移相关只是在第一项中确定R的情况下的得到的。是先固定旋转矩阵R,再单独分析平移t的最优解,所以在这个阶段,R被视为已知的 "常数",因此第二项只随t变化。 具体解释如下:

步骤 3:求解最优旋转矩阵R

现在需要求旋转矩阵R和平移矩阵T

将其带入目标函数E(R)得到关于θ的函数

对θ求导,当θ等于0时有极大值。

可以求出θ为如下表达式,ai,bi就是点集P和点集Q中的所有点,所以可以求出旋转矩阵的角度θ。

步骤 4:确定平移矩阵t*

由于在步骤二中已经得到平移矩阵的表达式,将求得的旋转矩阵R以及点云质心带入即可。

带入后公式为:Amean和Bmean就是点云质心

https://blog.csdn.net/qq_32618327/article/details/113997681

https://www.doubao.com/chat/32180146044744450

三、优化思路:

1.通过欧氏距离找到的两个点云之间距离最近的点对,实际情况中不一定是真实对应的,这种情况就会拉高计算出的点云之间的距离。可以通过赋予不同的权重来优化。

相关推荐
松涛和鸣9 分钟前
DAY38 TCP Network Programming
linux·网络·数据库·网络协议·tcp/ip·算法
ss27313 分钟前
ThreadPoolExecutor七大核心参数:从源码看线程池的设计
java·数据库·算法
qq_4335545424 分钟前
C++ 状压DP(01矩阵约束问题)
c++·算法·矩阵
虫小宝25 分钟前
返利app排行榜系统设计:基于大数据计算的实时排名算法实现
大数据·算法
C雨后彩虹29 分钟前
字符串拼接
java·数据结构·算法·华为·面试
LYFlied31 分钟前
【每日算法】LeetCode 279. 完全平方数(动态规划)
前端·算法·leetcode·面试·动态规划
scx201310041 小时前
20251201换根DP总结
算法·动态规划·换根dp
zd2005721 小时前
STREAMS指南:环境及宿主相关微生物组研究中的技术报告标准
人工智能·python·算法
TechNomad1 小时前
排序算法:基数排序算法
算法·排序算法
努力学算法的蒟蒻1 小时前
day43(12.24)——leetcode面试经典150
算法·leetcode·面试