R3LIVE项目实战(4) — 双目相机与激光雷达livox_camera_lidar_calibration联合标定

目录

步骤1: 环境配置

1.1 安装环境和驱动

1.2 安装依赖

1.3 下载源码,编译准备

1.4 程序节点概括

步骤2: 相机内参标定

2.1 前期准备

2.3 cameraCalib标定

2.4 内参结果

步骤3: 标定准备和数据采集

3.1 标定场景准备

3.2 连接雷达

3.3 连接相机

3.4 采集照片和点云数据

步骤4: 标定数据获取

4.1 参数设置

4.2 获得照片中的角点坐标

4.3 获得雷达点云中的角点坐标

5.2 外参计算getExt1节点

5.3 外参计算getExt2节点

步骤6: 结果验证与相关应用

6.1 概述

6.2 投影点云到照片

6.3 点云着色

注解:


本方案提供了一个手动校准Livox雷达和相机之间外参的方法,已经在LIVOX AVIA和ZED2i上进行了验证。其中包含了计算相机内参,获得标定数据,优化计算外参和雷达相机融合应用相关的代码。本方案中使用了标定板角点作为标定目标物,由于Livox雷达非重复性扫描的特点,点云的密度较大,比较易于找到雷达点云中角点的准确位置。相机雷达的标定和融合也可以得到不错的结果。

步骤1: 环境配置

(以下标定基于Ubuntu 20.04环境)

1.1 安装环境和驱动

安装ROS环境,安装 Livox SDK 和 livox_ros_driver 如已安装可以跳过此步骤。Livox雷达环境的配置可以参考文章:R3LIVE项目实战(2) — LIVOX AVIA激光雷达配置_livox 激光雷达_几度春风里的博客-CSDN博客

1.2 安装依赖

如已安装可以跳过此步骤。

  • PCL 安装

  • Eigen 安装

  • Ceres-solver 安装

1.3 下载源码,编译准备

git clone https://github.com/Livox-SDK/livox_camera_lidar_calibration.git
cd camera_lidar_calibration
catkin_make
source devel/setup.bash

1.4 程序节点概括

此项目包括如下节点:

  • cameraCalib - 标定相机内参

  • pcdTransfer - 将雷达点云rosbag转换成PCD文件

  • cornerPhoto - 获得照片角点

  • getExt1 - 计算外参节点1,只优化外参

  • getExt2 - 计算外参节点2,同时优化内参和外参

  • projectCloud - 把雷达点云投影到照片上

  • colorLidar - 雷达点云着色

以下程序节点中如果想修改launch文件,需要到src/calibration/launch文件夹中找对应的launch文件。

 

步骤2: 相机内参标定

2.1 前期准备

准备一块有黑白棋盘格的标定板(如下所示,可以打印出来)

2.3 cameraCalib标定

方法一:参考官方的MATLAB标定方法

方法二:使用自带的cameraCalib.launch

获得标定板各个角度的照片数据后,配置cameraCalib.launch中对应的路径和参数,默认是把照片数据放在data/camera/photos下,然后在data/camera/in.txt中写入所有需要使用的照片名称,如下图所示:

输入指令开始标定

roslaunch camera_lidar_calibration cameraCalib.launch

标定结果中会保存在data/camera/result.txt中,包括重投影误差,内参矩阵和畸变纠正参数。

方法三:使用相机官方的标定程序,以ZED相机为例,安装配置文件后在/usr/local/zed/tools/ZED_Calibration下的自动标定程序,具体看相机官方是否提供。

依次转动相机和图中红色圆圈重合即可 

2.4 内参结果

  1. 一个3x3的内参矩阵(IntrinsicMatrix)
  2. 5个畸变纠正参数 k1, k2, p1, p2, k3

 

步骤3: 标定准备和数据采集

3.1 标定场景准备

本方案使用标定板的四个角点来作为目标物 [注 2]。标定场景最好选择一个较为空旷的环境,这样方便识别标定板,并且保证雷达到标定板有3米以上。这个案例中使用了低反射率泡棉制作的标定板(1m x 1.5m)。需要选取至少10个左右不同的角度和距离来摆放标定板(参考相机内参的标定物摆放),左右位置和不同的偏向角度最好都有采集数据 [注 3]。

不同角度位置摆放标定板(本人不是用官方建议的泡棉)

3.2 连接雷达

检查标定板角点是否在点云中,输入点云可视化的命令查看点云

roslaunch livox_ros_driver livox_lidar_rviz.launch

需要录制rosbag时输入另一个命令

roslaunch livox_ros_driver livox_lidar_msg.launch

确认保存的rosbag数据格式是customMsg,后续程序中处理rosbag是对应的“livox custom msg format”格式。

3.3 连接相机

本方案中使用ZED双目相机,检查获取照片的质量,并检查标定板角点是否在照片中。

3.4 采集照片和点云数据

  1. 拍摄照片

  2. 运行指令录制点云

每个位置保存一张照片和10s左右的rosbag即可。数据采集完成后,将照片放在data/photo文件夹下; 雷达rosbag放在data/lidar文件夹下。

具体操作可参考博客3.5节:R3LIVE项目实战(3) —双目相机与激光雷达 lidar_camera_calib联合标定_几度春风里的博客-CSDN博客

 

步骤4: 标定数据获取

4.1 参数设置

首先需要把步骤2得到的内参和畸变纠正参数以下图的格式保存在data/parameters/intrinsic.txt文件下 

4.2 获得照片中的角点坐标

配置cornerPhoto.launch文件中的照片路径,运行

roslaunch camera_lidar_calibration cornerPhoto.launch

程序会在UI中打开对应的照片更改cornerPhoto.launch文件中的照片路径,重复上述流程,直至获得所有照片的角点坐标。源代码中会存在显示不出角点坐标的情况,具体可以参考下面的改进版本:  https://blog.csdn.net/qq_38650944/category_11751658.html​

4.3 获得雷达点云中的角点坐标

  1. 首先将bag文件装化为pcd文件, 在pcdTransfer.launch文件中配置相应的路径。
  2. 通过pcl_viewer选取角点。
roslaunch camera_lidar_calibration pcdTransfer.launch
pcl_viewer -use_point_picking xx.pcd

在计算前检查一下雷达和相机两个标定数据中是否每行对应的是同一个角点,并检查数据量是否相同[注 7]。

5.2 外参计算getExt1节点

计算前在getExt1.launch文件中配置好外参初值 [注 8],输入指令开始计算外参

roslaunch camera_lidar_calibration getExt1.launch

终端中可以看到每次迭代运算的cost,外参结果以齐次矩阵的格式保存到data/parameters/extrinsic.txt下。

可以根据优化后的残差和重投影误差评估一下得到的外参 [注 9]。

重投影会把误差较大的数据打印在屏幕上,可以剔除异常标定数据后再重新进行优化计算。

5.3 外参计算getExt2节点

getExt1节点只优化外参,而getExt2节点在计算的时候会将一开始计算的内参作为初值和外参一起优化。输入指令程序会得到一个新的内参和外参,并用新的参数来进行重投影验证。

roslaunch camera_lidar_calibration getExt2.launch

一般使用getExt1节点即可,如果在外参初值验证过,并且异常值已经剔除后,优化还是有较大的残差,那么可以使用getExt2试一试。使用的前提需要保证标定数据量较大,并且要充分验证结果。

如果经过验证getExt2计算的结果确实更好,那么把新的内参更新在data/parameters/intrinsic.txt中。

注意:在R3LIVE中设置外参时,要对此处的得到的外参结果求逆,不然得不到最后的点云着色效果。具体操作是将R按对角线反转,T取负号。

 

步骤6: 结果验证与相关应用

6.1 概述

获得外参后我们可以用两个常见的应用看一下融合的效果。第一个是将点云投影到照片上,第二个是点云的着色[注 10]。

6.2 投影点云到照片

在projectCloud.launch文件中配置点云和照片的路径后,运行指令,将rosbag中一定数量的点投影到照片上并且保存成新的照片。

roslaunch camera_lidar_calibration projectCloud.launch

6.3 点云着色

在colorLidar.launch文件中配置点云和照片的路径,运行指令,可以在rviz中检查着色的效果。

roslaunch camera_lidar_calibration colorLidar.launch

注解:

  1. 检查pcdTransfer.launch文件中的rosbag路径,设置rosbag的数量,并将rosbag以0.bag, 1.bag...命名。

  2. 运行指令将rosbag批量转化成PCD文件,PCD文件默认保存在data/pcdFiles文件夹中

  3. 使用pcl_viewer打开PCD文件,按住shift+左键点击即可获得对应的点坐标。注意和照片采用相同的角点顺序[注 6]。
  4. 将xyz角点坐标按如下格式保存在data/corner_lidar.txt中,将所有PCD文件中雷达点云的角点坐标保存下来。
  5. 打开pcl_viewer后可以输入"h"来获得指引。

  6. 注意少于10个字段不能被读取为计算数据,如果点云xyz或者照片xy坐标比较短需要补足10个字段。

  7. 程序中的默认初值是根据Livox激光雷达自身坐标系,雷达和相机的相对位置设置的,要根据情况进行修改。如果初值差的很大可能会导致不好的优化结果。

  8. 如果迭代结束cost还是比较大的量级(比如10的4次方), 那可能是程序中初值设置的有问题,得到的只是一个局部最优解,那么需要重新设置初值计算。

  9. 点云投影到照片是通过内外参矩阵将雷达的点云投影到照片对应的位置,点云的颜色会根据距离从近到远显示从蓝到红;点云的着色是通过点云的xyz和得到的内外参矩阵算出对应的相机像素坐标,获取到这个像素的RGB信息后再赋给点云显示出来,这样雷达点云可以显示真实的颜色。

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

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

相关文章

基于全新电脑环境安装pytorch的GPU版本

前言: 距离第一次安装深度学习的GPU环境已经过去了4年多(当时TensorFlow特别麻烦),现在发现安装pytorch的GPU版本还是很简单方便的,流程记录如下。 安装步骤: 步骤一:官网下载Anaconda Free…

Threejs里执行对象的多个动画

承接上文,本文讲述如何在Threejs里播放对象的多个动画,这也是研究了很久才解决的… 一 导出模型 在Blender里按照File->Export,选择glTF2.0 然后在弹框的右上角选择导出为glTF Embedded (.gltf) 这样就把模型导出来了,该模…

docker部署nginx,部署springboot项目,并实现访问

一、先部署springboot项目 1、安装docker: yum install docker -y 2、启动docker: service docker start 重启: service docker restart 3、查看版本: docker -v 4、使设置docker.service生效(路径:…

qt第二天

#include "widget.h" #include "ui_widget.h" #include "QDebug" Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this);this->resize(QSize(800,600)); //使用匿名对象,调用重…

HarmonyOS开发:超详细了解项目的工程结构

前言 系列文章目录: HarmonyOS开发第一步,熟知开发工具DevEco Studio 当我们熟练的掌握了DevEco Studio之后,就可以创建项目进行练习了,和市场上大多数IDE一样,DevEco Studio也给我们提供了很多的实例模板&#xff0c…

ElasticSearch-集成ik分词器

本文已收录于专栏 《中间件合集》 目录 背景介绍版本选择优势说明集成过程1.下载安装包2.解压安装包3.重启ElasticSearch服务3.1通过ps -ef | grep elastic查看正在启动的es进程号3.2使用kill -9 xxx 杀死进程3.3使用 ./elasticsearch 启动es服务 分词测试细粒度分词方式分词请…

【面试题】UDP和TCP有啥区别?

UDP UDP协议全称是用户数据报协议,在网络中它与TCP协议一样用于处理数据包,是一种无连接的协议。在OSI模型中,在第四层——传输层,处于IP协议的上一层。UDP有不提供数据包分组、组装和不能对数据包进行排序的缺点,也就…

基于stm32的烟雾浓度检测报警proteus仿真设计(仿真+程序+讲解)

基于STM32的烟雾浓度检测报警仿真设计(仿真程序讲解) 1.主要功能2.仿真3. 程序4. 资料清单&下载链接 基于STM32的烟雾浓度检测报警仿真设计(仿真程序讲解) 仿真图proteus 8.9 程序编译器:keil 5 编程语言:C语言 设计编号&a…

使用TPDSS连接GaussDB数据库

TPDSS是GaussDB官方提供的数据库连接工具,可以在TPDSS查看GaussDB的建库建表语句,于GaussDB使用兼容性比较好,由于TPDSS查找比较麻烦,下面给出了下载链接地址: 链接:https://pan.baidu.com/s/1Lqcu3KriE47…

打破数据孤岛,实现文档数据互通

随着数字经济加速发展,企业数字化转型正向更深层次推进。非结构化数据量也正在飞速增长,这些数据以文档、图片、音频等形式散落在组织内部,这给数据的整理和统一利用增加了难度。由于部门、应用、框架、多云环境等原因形成非结构化数据孤岛。…

JavaWeb 速通Ajax

目录 一、Ajax快速入门 1.基本介绍 : 2.使用原理 : 二、Ajax经典入门案例 1.需求 : 2.前端页面实现 : 3. 处理HTTP请求的servlet实现 4.引入jar包及druid配置文件、工具类 : 5.Domain层实现 : 6.DAO层实现 : 7.Service层实现 : 8.运行测试 : 三、JQuery操作Ajax 1 …

CI/CD 持续集成 持续交付

CI(Continuous integration)持续集成 参考:https://www.jianshu.com/p/2132949ff84a 持续集成是指多名开发者在开发不同功能代码的过程当中,可以频繁的将代码行合并到一起并切相互不影响工作。 持续集成的目的,是让…