【机器人-激光雷达】点云时间运动补偿

文章目录

激光雷达扫描畸变背景与运动补偿方法整理

一、问题背景

  • 车辆向前匀速行驶,速度 10 m/s
  • 激光雷达旋转扫描频率 10 Hz
  • 每帧扫描周期 100 ms (0.1s)

扫描期间车辆在运动,因此同一帧点云中的点并非采集于同一时刻:

时刻 激光扫描位置 车辆位置
t = 0 ms(帧头) 扫描到前方树,坐标 (10,0) 车辆位置 A
t =100 ms(帧尾) 扫描到后方房子,坐标(-10,0) 车辆位置 B(前进1m)

若直接拼成一个点云帧 = 不同时间点对应不同车辆位姿 → 必然畸变(扭曲)

失真原因

同一帧点云包含来自不同时间的扫描点,而车辆在这一段时间内发生了运动,导致整个点云处于不同坐标系下。


二、目标

将一帧点云中所有点的坐标对齐到同一个时间坐标系(统一参考时刻)

常用选择:对齐到该帧扫描结束的时刻(帧尾)


三、解决方法:基于IMU运动积分进行点云去畸变

核心思想:

对每个点使用 IMU 姿态解算和位移积分,求出其采样时刻相对于参考时刻的位姿变化,并反向补偿至统一坐标系。

处理流程(对齐到帧尾 ref_t)

对每个激光点 cur_p(其采样时间为 cur_t)处理如下:

  1. 找到参考时间戳 ref_t 在 IMU 数据中的区间

    复制代码
    (ref_t_imu_left, ref_t_imu_right]
  2. 找到每个点 cur_t 对应的 IMU 时间区间

    复制代码
    (cur_t_imu_left, cur_t_imu_right]
  3. IMU插值:计算 cur_t → cur_t_imu_right 的位姿变换矩阵

  4. IMU积分:计算 cur_t_imu_right → ref_t_imu_right 的位姿变换矩阵

  5. IMU插值:计算 ref_t_imu_right → ref_t 的位姿变换矩阵

  6. 将所有位姿相乘得到:

    复制代码
    T(cur_t → ref_t)
  7. 对点坐标进行补偿,统一变换到 ref_t 坐标系下


最终效果

所有点的空间位置均被校正到 同一参考时刻的车辆坐标系

解决扫描周期内运动引起的点云畸变,得到真实无扭曲的点云帧。

相关推荐
.548几秒前
Two Pointers(双指针)
java·数据结构·算法
sali-tec2 分钟前
C# 基于OpenCv的视觉工作流-章58-相机标定
图像处理·人工智能·数码相机·opencv·算法·计算机视觉
承渊政道2 分钟前
【动态规划算法】(回文串问题解题框架与经典案例)
数据结构·c++·学习·算法·leetcode·动态规划·哈希算法
一水鉴天3 分钟前
同构异质三表总装体系确立与入表机制闭环验证 20260502(腾讯元宝)
人工智能·算法·机器学习
qyzm11 分钟前
Codeforces Round 1073 (Div. 2)
数据结构·python·算法
深邃-2 小时前
【数据结构与算法】-二叉树(2):实现顺序结构二叉树(堆的实现),向上调整算法,向下调整算法,堆排序,TOP-K问题
数据结构·算法·二叉树·排序算法·堆排序··top-k
We་ct5 小时前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·javascript·算法·leetcode·typescript
工业机器人生命周期管理9 小时前
赢胜智能:五一劳动节快乐
机器人
王老师青少年编程9 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮10 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化