单线激光雷达(SICK)驱动安装及时空标定
创始人
2024-05-29 21:18:08
0

一、引言

1、AGV需要同时具备定位、避障与导航的功能,其中避障对于雷达本身的分辨率、精度要求并不是很高,只需要能够根据预设定的雷达扫描范围准确避开障碍物即可,故本文以TIM240(SICK激光类雷达)为例介绍实现多雷达时空标定的问题。
2、多个避障雷达可能会被安装在车体各个位置,并且不一定有重叠区域,所以通过提取特征点再进行ICP或NDT配准的方法获取相对位姿变换关系的方式不可行,由于机械结构本身已经按照设计图纸预先设置好雷达的安装位置,所以雷达之间的相对位置关系相对准确,故可以直接利用已有参数可以进行雷达空间标定,将两个雷达数据统一到同一个坐标系下进行,需要用到PCL库。
3、坐标变换实际使用过程当中确实可以用tf进行静态坐标变换,但是相比较直接手动写代码进行转换延迟较高,故采用手动根据相对位置关系进行坐标变换的方式。
4、进行时空标定步骤主要分为:(1)驱动安装及雷达参数配置(2)雷达时间同步(3)雷达空间同步(Rp+T,这里的旋转矩阵和平移矩阵的定义后文会给出)

二、整体思路与流程

1、SICK激光雷达驱动安装
新买的SICK雷达不仅需要安装驱动,还需要进配置文件修改参数才能正常工作
(1)安装驱动

mkdir -p ./sick_scan_ws
cd ./sick_scan_wsmkdir ./src
pushd ./src
git clone https://ghproxy.com/https://github.com/SICKAG/libsick_ldmrs.git
git clone https://ghproxy.com/https://github.com/SICKAG/msgpack11.git
git clone https://ghproxy.com/https://github.com/SICKAG/sick_scan_xd.git
popdmkdir -p ./build/msgpack11
pushd ./build/msgpack11
cmake -G "Unix Makefiles" -D CMAKE_CXX_FLAGS=-fPIC -D CMAKE_BUILD_TYPE=Release -D MSGPACK11_BUILD_TESTS=0 ../../src/msgpack11
make
sudo make install
popdsource /opt/ros/melodic/setup.bash # replace noetic by your ros distro
catkin_make_isolated --install --cmake-args -DROS_VERSION=1 -Wno-dev
source ./devel_isolated/setup.bash

(2)雷达配置文件修改
1)首先需要设置PC机的以太网ip端口号如:192.168.0.2
2)SICK官网下载sopas软件,在Windows端使用(用Win10系统,Win11有问题)
3)进入软件,修改登录权限为授权的用户,密码是client
在这里插入图片描述
4)修改雷达ip(与PC机同一网段即可,192.168.0.1以及Cola dialect改为cola binary格式。此处修改雷达ip是为了保证两个雷达能同时使用
在这里插入图片描述
(3)硬件组装
需要交换机、电源模块、电源线(普通的家庭供电线就可以,火线为棕灰色、地线为黄绿双色、零线为蓝色,分别对应接到电源模块的L端、FG端、N端)、供电线、网线,如下图连接示意图
在这里插入图片描述
(4)修改雷达启动文件(launch),需要创建两个启动文件,分别对应不同ip的雷达,我这里设置一个ip为192.168.0.1,一个为192.168.0.3,因为PC的ip为192.168.0.2



                                            

2、SICK激光雷达时间同步
主要使用ros官方提供的软同步方式(message_filters
使用方式如下:

ros::Publisher pointcloud_pub;
typedef message_filters::sync_policies::ApproximateTime testSyncPolicy;void callback(const sensor_msgs::PointCloud2ConstPtr &point1, const sensor_msgs::PointCloud2ConstPtr &point2)  //回调中包含多个消息
{//需要处理的内容//
}int main (int argc, char **argv)
{ros::init (argc, argv, "lidar2base");ros::NodeHandle n;pointcloud_pub = n.advertise("/scan", 1000);//发布的话题message_filters::Subscriber pointcloud1_sub(n, "/cloud1", 1);// 需要同步的topic1message_filters::Subscriber pointcloud2_sub(n, "/cloud2", 1);// 需要同步的topic2 message_filters::Synchronizer sync(testSyncPolicy(10), pointcloud1_sub, pointcloud2_sub);// 同步sync.registerCallback(boost::bind(&callback, _1, _2));ros::spin();ros::shutdown();return 0;
}

3、SICK激光雷达空间同步
主要是通过雷达之间的旋转和平移参数将两个雷达数据统一到一个坐标系下再使用PCL库对雷达数据进行融合,这里编写了相关函数

//坐标变换将激光雷达坐标系下的点转换到小车坐标系下
void transPoint(pcl::PointCloud::Ptr lidarCloud,pcl::PointCloud::Ptr carCloud,double yaw,double pitch,double roll,double x,double y,double z)
{Eigen::Matrix4f transform=Eigen::Matrix4f::Identity();Eigen::Matrix4f transformYaw;Eigen::Matrix4f transformPitch;Eigen::Matrix4f transformRoll;//航向角transformYaw<

如下图:
需求是通过上述函数将P点从激光雷达坐标系变换到车体坐标系,函数的输入分别为偏航角yaw, pitch, roll,x,y,z
在这里插入图片描述
偏航角yaw的获取方式是:以车坐标系为右手基准坐标系,大拇指指向为z轴正方向,激光雷达系为目标坐标系,顺时针旋转z轴的角度分量为yaw的值,图中x1Oy1为车体坐标系。
同理俯仰角pictch为绕y轴旋转角度分量,横滚角roll为绕x轴的分量。
平移分量(x, y, z)是激光雷达相对于车体坐标原点的x,y,z的坐标。

在这里插入图片描述4、雷达数据融合
需要将ros的PointCloud2类型数据转换为PCL数据类型,而后将PCL数据类型转为ros的LaserScan数据类型。
1)数据融合主要在SICK激光雷达时间同步这一部分的回调函数中写:

    pcl::PointCloud::Ptr colorcloud1(new pcl::PointCloud);pcl::fromROSMsg(*point1, *colorcloud1);pcl::PointCloud::Ptr colorcloud2(new pcl::PointCloud);pcl::fromROSMsg(*point2, *colorcloud2);pcl::PointCloud::Ptr output_points1(new pcl::PointCloud);pcl::PointCloud::Ptr output_points2(new pcl::PointCloud);transPoint(colorcloud1, output_points1, yaw1, pitch1, roll1, x1, y11, z1);transPoint(colorcloud2, output_points2, yaw2, pitch2, roll2, x2, y2, z2);pcl::PointCloud output = *output_points1 + *output_points2;//pcl::toROSMsg((*output_points1 + *output_points2), output);//以实时发布的方式发布sensor_msgs::LaserScan output2 = PointCloudToLaserscan(output);output2.header.frame_id = "base_link";pointcloud_pub.publish(output2);

2)PCL转LaserScan单独写了一个函数

sensor_msgs::LaserScan PointCloudToLaserscan(pcl::PointCloud& _pointcloud)
{float angle_min, angle_max, range_min, range_max, angle_increment;//需要自行调整的参数angle_min = -2.094395102;angle_max =  2.094395102;range_min = 0.05;range_max = 10;//角度分辨率,分辨率越小,转换后的误差越小angle_increment = 0.0174444444;//计算扫描点个数unsigned int beam_size = ceil((angle_max - angle_min) / angle_increment);sensor_msgs::LaserScan output;output.header.stamp = ros::Time::now();output.header.frame_id = "base_link";output.angle_min = angle_min;output.angle_max = angle_max;output.range_min = range_min;output.range_max = range_max;output.angle_increment = angle_increment;output.time_increment = 0.0;output.scan_time = 0.0;//先将所有数据用nan填充output.ranges.assign(beam_size, std::numeric_limits::quiet_NaN());//output.intensities.assign(beam_size, std::numeric_limits::quiet_NaN());for (auto point : _pointcloud.points){float range = hypot(point.x, point.y);float angle = atan2(point.y, point.x);int index = (int)((angle - output.angle_min) / output.angle_increment);if (index >= 0 && index < beam_size){//如果当前内容为nan,则直接赋值if (isnan(output.ranges[index])){output.ranges[index] = range;}//否则,只有距离小于当前值时,才可以重新赋值else{if (range < output.ranges[index]){output.ranges[index] = range;}}//output.intensities[index] = point.intensity;}}return output;
}

5、创建启动脚本
首先启动两个雷达,其次启动坐标转换的脚本,即可实现两个雷达的时空同步

#!/bin/bash
gnome-terminal --tab -- bash -c "roslaunch sick_scan sick_tim_240_1.launch"
sleep 1s
gnome-terminal --tab -- bash -c "roslaunch sick_scan sick_tim_240_2.launch "
sleep 2s
gnome-terminal --tab -- bash -c "source /home/lixushi/catkin_ws/devel/setup.bash; roslaunch lidar2base lidar2base.launch"

如下图为雷达实际摆放位置
在这里插入图片描述

转换前的点云图
在这里插入图片描述
转换后的点云图
在这里插入图片描述

三、参考文献

[1] https://blog.csdn.net/m0_68312479/article/details/128266483
[2] https://blog.csdn.net/hltt3838/article/details/123067620
[3] https://blog.csdn.net/m0_68312479/article/details/128266483
[4] https://adamshan.blog.csdn.net/article/details/105930565?spm=1001.2014.3001.5502
[5] https://mp.weixin.qq.com/s?__biz=MzU1NjEwMTY0Mw==&mid=2247556040&idx=1&sn=fa1f7cc63f7aeeaed69242add86efd75&chksm=fbc862acccbfebba12fd29cef32b7a34ac296f54e8ef6f19485aff81ebddd794a3364419c90b&scene=27

相关内容

热门资讯

安装系统怎么选usb,安装系统... 安装系统时如何选择USB启动?详细指南一、准备USB启动盘在开始安装系统之前,首先需要制作一个USB...
蚌埠系统门窗安装流程,蚌埠系统... 蚌埠系统门窗安装流程详解随着人们对居住环境要求的提高,系统门窗因其优异的性能和美观的外观,越来越受到...
安装自制系统fsd,Xbox ... Xbox 360自制系统FSD安装教程随着游戏机的普及,越来越多的玩家开始尝试在Xbox 360上安...
清华同方系统安装黑屏,清华同方... 清华同方电脑系统安装黑屏问题解析及解决方法一、黑屏原因分析1. 硬件故障:电脑硬件故障是导致系统安装...
安装治安系统入账,治安系统安装... 治安系统安装入账流程详解随着社会治安形势的日益复杂,治安系统的安装与维护已成为保障社会安全的重要手段...
安卓安装win7系统,如何在安... 如何在安卓设备上安装Windows 7系统一、准备工作在开始安装Windows 7之前,您需要做好以...
安装原版系统bootmgr 安装原版系统Bootmgr:解决系统引导问题 重拾流畅体验在电脑使用过程中,我们可能会遇到各种...
宝塔系统安装证书,宝塔系统安装... 宝塔系统安装SSL证书的详细教程随着网络安全意识的不断提高,越来越多的网站开始使用SSL证书来保障用...
安卓怎么安装系统更新包,安卓手... 安卓手机系统更新包安装指南一、通过官方渠道更新系统1. 打开手机设置首先,在手机主屏幕上找到并点击“...
安装在虚拟机的系统怎么安装wi... 如何在虚拟机中安装Windows 7系统 准备阶段在开始安装Windows 7系统之前,我们需要做一...
安装显卡导致系统崩溃,原因与解... 显卡驱动安装不当导致系统崩溃:原因与解决方法随着电脑硬件的不断发展,显卡作为电脑性能的重要组成部分,...
报警系统安装联网,守护安全,构... 报警系统安装联网:守护安全,构建智慧社区随着社会的发展和科技的进步,报警系统的安装与联网已经成为现代...
安卓系统凭密码安装应用,安全与... 安卓系统凭密码安装应用:安全与便捷的双重保障随着智能手机的普及,安卓系统因其开放性和丰富的应用生态而...
北斗定位系统模块安装,技术革新... 北斗定位系统模块安装:技术革新助力多领域发展一、北斗定位系统模块简介北斗定位系统是我国自主研发的全球...
白城电脑系统安装价钱,电脑系统... 白城电脑系统安装价格一览,让您明明白白消费一、电脑系统安装的必要性电脑系统是电脑的核心组成部分,它负...
驱动安装卡在系统检查,驱动安装... 驱动安装卡在系统检查怎么办?解决方法大揭秘在电脑使用过程中,我们经常会遇到各种问题,其中驱动安装卡在...
安装鱼缸底滤系统,鱼缸底滤系统... 鱼缸底滤系统安装全攻略鱼缸底滤系统是维护鱼缸水质的重要设备,它能有效过滤掉鱼缸中的杂质和有害物质,为...
清洁大师如何安装系统,清洁大师... 清洁大师U盘安装系统教程一、准备工作在开始安装系统之前,我们需要做好以下准备工作: 准备一个至少2...
安装系统展开文件时蓝屏,安装系... 安装系统展开文件时蓝屏的原因及解决方法在电脑使用过程中,遇到安装系统展开文件时蓝屏的情况,无疑会让用...
清灰后安装系统更新,电脑清灰后... 电脑清灰后,系统更新的重要性与操作指南随着电脑使用时间的增长,灰尘的积累会严重影响电脑的散热性能,进...