【LIO-SAM 跑自录数据集】

2023-11-08 17:59
文章标签 数据 sam lio 自录

本文主要是介绍【LIO-SAM 跑自录数据集】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

LIO-SAM

测试环境: Ubuntu18.04 ROS melodic
激光雷达:RS16
组合惯导:华测CGI-410(频率100HZ)

一、数据格式

1.1 IMU数据格式
作者用的九轴IMU,本次测试用的六轴,未对源码修改。
注:IMU单位:rad/s;m/s^2;rad;
IMU坐标:y前,x右,z上(作者:x前,y左,z上)

1.2 Lidar 数据格式
LIO-SAM要求激光雷达的数据格式:XYZIRT
更改:rslidar_sdk中的CMakeLists.txt

#=======================================
# Custom Point Type (XYZI, XYZIRT)
#=======================================
set(POINT_TYPE XYZIRT)

安装rs_to_velodyne转化节点:

  1. 安装好最新的驱动之后,打开lidar_sdk工作空间/src/rslidar_sdk文件位置与rslidar_sdk并列新建workspace,再新建src,src安装rs_to_velodyne包,并编译。
git clone https://github.com/HViktorTsoi/rs_to_velodyne.git
cd ..
catkin_make
  1. 在与src并列的位置新建launch文件夹,在launch文件夹内新建rs2velodyne.launch文件用来启动节点,并在launch内写入
<launch><node pkg="rs_to_velodyne" name="rs_to_velodyne" type="rs_to_velodyne"  args="XYZIRT XYZIRT"   output="screen"></node>
</launch>
  1. 将转化节点写入同一launch文件
<launch><node pkg="rslidar_sdk" name="rslidar_sdk_node" type="rslidar_sdk_node" output="screen"><param name="config_path" value=""/></node><!-- rviz --><!--<node pkg="rviz" name="rviz" type="rviz" args="-d $(find rslidar_sdk)/rviz/rviz.rviz" />--><include file="$(find rs_to_velodyne)/launch/rs2velodyne.launch" /> 
</launch>

1.3 GPS数据要求
目前只注意到GPS数据格式为:sensor_msgs/NavSatFix

1.4 话题及frame_id
为了调试方便,更改自录数据集传感器话题和frame_id

// Lidar
/points_raw   --------------> frame_id:"velodyne"
// IMU
/imu_raw        --------------> frame_id:"imu_link"
// GPS
/gps_driver    -------------->frame_id:"navsat_link"

二、IMU内参标定及Lidar和IMU的外参标定
参考:标定.
注:本次实验IMU和Lidar坐标系均为:y前,x右,z上
IMU内参及lidar->IMU的平移旋转均为默认的配置文件。


三、下载LIO-SAM并编译

3.1 安装相关依赖包

sudo apt-get install -y ros-kinetic-navigation
sudo apt-get install -y ros-kinetic-robot-localization
sudo apt-get install -y ros-kinetic-robot-state-publisher 

3.2 安装GTSAM 4.0.2

git clone https://github.com/borglab/gtsam.git
mkdir build && cd build
cmake -DGTSAM_BUILD_WITH_MARCH_NATIVE=OFF ..
sudo make install -j4

3.3 下载lio-sam、编译

cd ~/catkin_ws/src
git clone https://github.com/TixiaoShan/LIO-SAM.git
cd ../
catkin_make

四、修改LIO-SAM配置参数

4.1 params.yaml
打开config文件下的params.yaml

  # TopicspointCloudTopic: "/points_raw"               # Point cloud data (雷达话题)imuTopic: "/imu_raw"                                  # IMU data  (IMU话题)odomTopic: "odometry/imu"                   # IMU pre-preintegration odometry, same frequency as IMUgpsTopic: "odometry/gps"                        # GPS odometry topic from navsat, see module_navsat.launch file
# GPS SettingsuseImuHeadingInitialization: true           # if using GPS data, set to "true" (使用GPS,改为true)useGpsElevation: false                      # if GPS elevation is bad, set to "false"gpsCovThreshold: 2.0                        # m^2, threshold for using GPS dataposeCovThreshold: 1.0                      # m^2, threshold for using GPS data

这里用的是默认参数,根据实际情况做进一步修改。

 # Extrinsics (lidar -> IMU)extrinsicTrans: [0.0, 0.0, 0.0]# extrinsicRot: [-1, 0, 0,#                 0, 1, 0,#                 0, 0, -1]#extrinsicRPY: [0,  1, 0,#                -1, 0, 0,#                 0, 0, 1]extrinsicRot: [1, 0, 0,0, 1, 0,0, 0, 1]extrinsicRPY: [1, 0, 0,0, 1, 0,0, 0, 1]

其余地方暂未作修改。

4.2 module_navsat.launch
打开launch/include/module_navsat.launch文件

<launch><arg name="project" default="lio_sam"/><env name="ROSCONSOLE_CONFIG_FILE" value="$(find lio_sam)/launch/include/rosconsole/rosconsole_error.conf"/><!-- EKF GPS--><node pkg="robot_localization" type="ekf_localization_node" name="ekf_gps" respawn="true"><remap from="odometry/filtered" to="odometry/navsat" /></node><!-- Navsat --><node pkg="robot_localization" type="navsat_transform_node" name="navsat" respawn="true"><!-- <rosparam param="datum">[42.35893211, -71.09345588, 0.0, world, base_link]</rosparam> --><remap from="imu/data" to="/imu_raw" />    // 修改为自己的Imu话题<remap from="gps/fix" to="/gps_driver" />    // 修改为自己的gps话题<remap from="odometry/filtered" to="odometry/navsat" /></node></launch>

五、运行

source devel/setup.bash
roslaunch lio-sam run.launch

生成的全局点云图
在这里插入图片描述

GPS约束

这里外参转换因为用的默认的,所以GPS在下面
在这里插入图片描述

点云地图和轨迹
在这里插入图片描述
点云地图和GPS轨迹
在这里插入图片描述

lidar odom和gps 轨迹

高程方向还有很大的误差
在这里插入图片描述


参考

  1. LIO-SAM运行自己数据包遇到的问题解决–SLAM不学无数术小问题.
  2. lio-sam运行自己的rosbag.
  3. ubuntu18运行编译LIO-SAM并用官网和自己的数据建图(修改汇总).

这篇关于【LIO-SAM 跑自录数据集】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/371546

相关文章

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的

Navicat数据表的数据添加,删除及使用sql完成数据的添加过程

《Navicat数据表的数据添加,删除及使用sql完成数据的添加过程》:本文主要介绍Navicat数据表的数据添加,删除及使用sql完成数据的添加过程,具有很好的参考价值,希望对大家有所帮助,如有... 目录Navicat数据表数据添加,删除及使用sql完成数据添加选中操作的表则出现如下界面,查看左下角从左

SpringBoot中4种数据水平分片策略

《SpringBoot中4种数据水平分片策略》数据水平分片作为一种水平扩展策略,通过将数据分散到多个物理节点上,有效解决了存储容量和性能瓶颈问题,下面小编就来和大家分享4种数据分片策略吧... 目录一、前言二、哈希分片2.1 原理2.2 SpringBoot实现2.3 优缺点分析2.4 适用场景三、范围分片

Redis分片集群、数据读写规则问题小结

《Redis分片集群、数据读写规则问题小结》本文介绍了Redis分片集群的原理,通过数据分片和哈希槽机制解决单机内存限制与写瓶颈问题,实现分布式存储和高并发处理,但存在通信开销大、维护复杂及对事务支持... 目录一、分片集群解android决的问题二、分片集群图解 分片集群特征如何解决的上述问题?(与哨兵模

浅析如何保证MySQL与Redis数据一致性

《浅析如何保证MySQL与Redis数据一致性》在互联网应用中,MySQL作为持久化存储引擎,Redis作为高性能缓存层,两者的组合能有效提升系统性能,下面我们来看看如何保证两者的数据一致性吧... 目录一、数据不一致性的根源1.1 典型不一致场景1.2 关键矛盾点二、一致性保障策略2.1 基础策略:更新数

Oracle 数据库数据操作如何精通 INSERT, UPDATE, DELETE

《Oracle数据库数据操作如何精通INSERT,UPDATE,DELETE》在Oracle数据库中,对表内数据进行增加、修改和删除操作是通过数据操作语言来完成的,下面给大家介绍Oracle数... 目录思维导图一、插入数据 (INSERT)1.1 插入单行数据,指定所有列的值语法:1.2 插入单行数据,指

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名