开源自主导航小车MickX4(五)gmapping建图

2023-05-16

开源自主导航小车MickX4(五)gmapping建图

  • 1 激光雷达驱动
  • 2 3D点云到2D点云的转换
  • 3 gmapping 建图
    • 3.1 安装 gmapping库
    • 3.2 配置 gmapping
    • 3.3 启动 gmapping
    • 3.4 保存地图
  • 总结
  • 参考资料

本章节主要描述了在室外环境如何把3D激光压缩称为2D通过gmapping建图。

1 激光雷达驱动

在读取数据时注意激光雷达的IP地址和你使用的路由器的IP网段以及电脑的IP一致。如果激光雷达是直接连上工控机的,则需要你自己设置工控机的IP为与激光雷达同一网段的静态IP。

这里我们使用的是速腾16线的3D激光雷达,这里主要参考了博客[1]对激光雷达的数据进行读取

在这里插入图片描述

这里需要注意一个问题: 速腾16线的3D激光雷达定义的坐标系是基线头指向Y轴的负方向,但是厂家的驱动里面进行了坐标系转换,转换成为了ROS下的右手坐标系。在文档的23页有注释说明。

在这里插入图片描述

2 3D点云到2D点云的转换

由于gmaping是2D激光SLAM的算法,不能直接使用3D点云建图,因此这里需要使用一个额外的包 pointcloud_to_laserscan[2] 将雷达采集到的3D点云压成2D点云。

这里需要注意一个问题,如果启动gmapping的时候出现报错,这主要是由于gmapping的堆栈大小的原因,3D转2D的时候点太密集,gmapping默认的堆栈太小,解决方法有两个:1是下载边缘gmapping的源码,手动把堆栈设置到4096大小。另一个方法就是把 pointcloud_to_laserscan 包中 angle_increment 调小一些,这样点就没有那么密,数据量就小了。
在这里插入图片描述

我所使用的配置参数如下:

<?xml version="1.0"?>

<launch>
    <!-- run pointcloud_to_laserscan node -->
    <node pkg="pointcloud_to_laserscan" type="pointcloud_to_laserscan_node" name="pointcloud_to_laserscan">
        <remap from="cloud_in" to="/rslidar_points"/>
        <rosparam>
            target_frame: rslidar # Leave disabled to output scan in pointcloud frame
            transform_tolerance: 0.01
            min_height: -1.5
            max_height: 20

            angle_min: -3.1415926 # -M_PI
            angle_max: 3.1415926 # M_PI
            angle_increment: 0.03 # M_PI/360.0
            scan_time: 0.1
            range_min: 0.2
            range_max: 100.0
            use_inf: true
            inf_epsilon: 1.0

            # Concurrency level, affects number of pointclouds queued for processing and number of threads used
            # 0 : Detect number of cores
            # 1 : Single threaded
            # 2->inf : Parallelism level
            concurrency_level: 2
        </rosparam>

    </node>
</launch>

这里3D转2D的效果并不好,这个包感觉上只是截取了集中一层的线条做映射。修改以后的包[4]
在这里插入图片描述

3 gmapping 建图

gmapping使用的条件主要由三个:

  • 激光雷达数据 /scan (这里我们通过 pointcloud_to_laserscan 包把3D雷达压缩成为了2D提供到gmapping中)
  • 里程计数据 /odom 话题(由底盘发布的里程计数据,这里由底盘节点mick_bringup节点包提供)
  • TF变换数据 提供base_link、odmo和laser 的变换关系(base_link和odom之间的变换关系可以由发布/odom的节点提供,而激光雷达和基坐标系也就是 laser和base_link之间的变换关系可以URDF模型提供,或者是用在launch文件中写入静态的TF变换)

gmapping输出的话题有:/map的地图数据,以及一个获取地图的服务(在建图完成以后保存地图用)

图片来源于[3]
在这里插入图片描述

3.1 安装 gmapping库

sudo apt-get install ros-kinetic-gmapping       #根据ROS的版本更改

3.2 配置 gmapping

配置好坐标系关系以后,接下来我们需要配置gmapping的运行参数(我自己设置的运行参数如下),新建一个文件夹“mick_navigation”,在该文件夹中建立名为"launch"的文件夹,编写gmapping.launch文件:

<?xml version="1.0"?>
<launch>

  <arg name="scan_topic" default="scan" />

  <node pkg="gmapping" type="slam_gmapping" name="slam_gmapping" output="screen">

    <param name="odom_frame" value="odom"/>
    <param name="base_frame" value="base_link"/>
    <param name="map_frame" value="map"/>

    <!-- Process 1 out of every this many scans (set it to a higher number to skip more scans)  -->
    <param name="throttle_scans" value="1"/>

    <param name="map_update_interval" value="5.0"/> <!-- default: 5.0 -->

    <!-- The maximum usable range of the laser. A beam is cropped to this value.  -->
    <param name="maxUrange" value="5.0"/>

    <!-- The maximum range of the sensor. If regions with no obstacles within the range of the sensor should appear as free space in the map, set maxUrange < maximum range of the real sensor <= maxRange -->
    <param name="maxRange" value="10.0"/>

    <param name="sigma" value="0.05"/>
    <param name="kernelSize" value="1"/>
    <param name="lstep" value="0.05"/>
    <param name="astep" value="0.05"/>
    <param name="iterations" value="5"/>
    <param name="lsigma" value="0.075"/>
    <param name="ogain" value="3.0"/>
    <param name="minimumScore" value="0.0"/>
    <!-- Number of beams to skip in each scan. -->
    <param name="lskip" value="0"/>

    <param name="srr" value="0.01"/>
    <param name="srt" value="0.02"/>
    <param name="str" value="0.01"/>
    <param name="stt" value="0.02"/>

    <!-- Process a scan each time the robot translates this far  -->
    <param name="linearUpdate" value="0.1"/>

    <!-- Process a scan each time the robot rotates this far  -->
    <param name="angularUpdate" value="0.05"/>

    <param name="temporalUpdate" value="-1.0"/>
    <param name="resampleThreshold" value="0.5"/>

    <!-- Number of particles in the filter. default 30        -->
    <param name="particles" value="10"/>

<!-- Initial map size  -->
    <param name="xmin" value="-10.0"/>
    <param name="ymin" value="-10.0"/>
    <param name="xmax" value="10.0"/>
    <param name="ymax" value="10.0"/>

    <!-- Processing parameters (resolution of the map)  -->
    <param name="delta" value="0.02"/>

    <param name="llsamplerange" value="0.01"/>
    <param name="llsamplestep" value="0.01"/>
    <param name="lasamplerange" value="0.005"/>
    <param name="lasamplestep" value="0.005"/>

    <remap from="scan" to="$(arg scan_topic)"/>
  </node>
</launch>

3.3 启动 gmapping

接下来我们启动相应的节点实现地图的扫描,首先我们要启动激光雷达、pointcloud_to_laserscan和底盘三个节点。这里我们把这几个launch文件写入到一个launch中,让其一起启动。在中新建launch文件 mickx4_gmapping.launch 写入一下内容:

<?xml version="1.0"?>
<launch>
  <arg name="rviz" default="true"/>
   <!-- chassis -->
  <include file="$(find mick_bringup)/launch/mickx4_bringup.launch" />

   <!-- imu -->
  <include file="$(find imu_driver)/launch/wit_imu.launch" />

   <!-- urdf -->
  <include file="$(find mick_description)/launch/state_publisher.launch" />

   <!-- rslidar -->
  <include file="$(find rslidar_pointcloud)/launch/rs_lidar_16.launch" />
 
   <!-- pointcloud_to_laserscan -->
  <include file="$(find pointcloud_to_laserscan)/launch/rslidar.launch" />

  <!-- Gmapping -->
  <include file="$(find mick_navigation)/launch/gmapping_no_rviz.launch" />
  
 <!-- RViz -->
  <node if="$(arg rviz)" pkg="rviz" type="rviz" name="$(anon rviz)" respawn="false" output="screen" args="-d $(find mick_navigation)/rviz/gmapping.rviz" />


</launch>

最后新打开一个终端,启动gmapping节点

source / catkin_ws/devel/setup.bash
roslaunch mick_navigation mickx4_gmapping.launch

这里的场景是一个小范围的场景,小车行走的距离大概是500m左右,建图过程中发现很多问题,比如说在室外使用3D转到2D以后,这个激光的会有很多的噪点,激光数据延时也比较大。在比较空旷的地方转弯会使得车辆转弯估计不准,这是由于我们限定了3D-2D时候激光的测量范围,比如在十字路口的时候就会有一个‘’缺口“”存在,不像在室内环境激光都是一个完整的圈,因此此时旋转车就会使得地图建立的不准。

MickX4 gmapping 室外2D建图

3.4 保存地图

扫描完毕以后你需要运行map_server节点来保存地图,最后获得两个文件(xxx.png和 xxx.yaml)

rosrun map_server map_saver -f test

.png 主要是地图文件、.yaml 包含有地图的参数,精度之类的。

在这里插入图片描述

总结

1、3D转2D时候这个包只保留了一条线,如果新建一个节点直接把Z轴压缩,把激光压缩到一个平面上,这样就会有很多条线的包罗在一起,在通过滤波处理一下,不知道效果会不会好一些?
2、gamapping在运行的时候依赖odom,如果odom不准确的话会使得gmapping建图的效果就会很差。 4轮差速模型转弯时候由于轮胎会和地面滑动摩擦,这会造成odom误差变大,尤其是没有加入IMU而直接使用轮子的差速模型计算航向角,以下是一个使用轮子计算yaw角导致odom不准的失败案例。

MickX4 gmapping 建图失败例子

参考资料

[1] https://www.jianshu.com/p/4bf7102d661c?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation
[2] http://wiki.ros.org/pointcloud_to_laserscan
[3] https://blog.csdn.net/zhao_ke_xue/article/details/108944811

上一篇:开源自主导航小车MickX4(四)底盘URDF模型

下一篇:开源自主导航小车MickX4(六)cartographer 室外2D建图

欢迎大家点赞在评论区交流讨论(cenruping@vip.qq.com) O(∩_∩)O

或者加群交流(1149897304)
在这里插入图片描述

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

开源自主导航小车MickX4(五)gmapping建图 的相关文章

  • SVN查看所有日志提交记录

    1 svn默认显示最近一周的文件提交和修改记录 xff0c 怎么查看更长时间的日志记录呢 xff1f 2 TortoiseSVN 3 点击show all 或者NEXT 100 xff0c 就可显示更长时间的文件提交记录
  • Nearest neighbor graph | 近邻图

    最近在开发一套自己的单细胞分析方法 xff0c 所以copy paste事业有所停顿 实例 xff1a R eNetIt v0 1 1 data ralu site Saturated spatial graph sat graph lt
  • 手把手教你实现一个简单的编译器

    手把手教你实现一个简单的编译器 1 概述 今天我们将学习开发一个编译器 xff0c 但是呢 xff0c 这个编译器并不是说什么都能都编译 xff0c 它只是一个超级小的编译器 xff0c 主要用于说明编译器的一些基本的原理 我们这个编译器可
  • 查看struts版本号

    2019独角兽企业重金招聘Python工程师标准 gt gt gt struts版本信息查看方法 xff1a 查看lib中的 struts2 core jar META INF MANIFEST MF 找到Implementation Ve
  • R语言读取大数据 data.table包 fread函数

    gt setwd 34 D R Tardy 34 gt library data table data table 1 9 6 For help type data table or https github com Rdatatable
  • Android中读取文本文件中内容的方法

    这几天在项目开发中 xff0c 要读取文本文件中内容的 xff0c 因此写了个读取文本文件中内容的方法 xff0c 代码如下 xff1a 读取文本文件中的内容 public static String ReadTxtFile String
  • Error creating bean with name 'objectMapperConfigurer' defined in class path resource

    转载于 https www cnblogs com qianjinyan p 10879065 html
  • C#实现Windows 服务的制作安装和删除[转]

    关于C 实现windows服务的制作与安装还有删除 运行Visual Studio NET xff0c 建立一个C 的Windows服务项目 主程序代码 xff1a 以下是引用片段 xff1a Code using System using
  • 相机与IMU联合标定

    相机与IMU联合标定 1 imu utils 标定IMU的内参1 1 安装环境1 2 录制IMU数据集 2 kalibr 标定工具2 1 安装2 2 校准相机的内外参2 3 校准相机与IMU外参 总结参考资料 1 imu utils标定IM
  • matlab练习程序(寻找凸包,Graham扫描法)

    我不太清楚这个凸包在图像处理中到底会怎样的运用 xff0c 因为这个好像更多的是计算几何或是图形学里面的东西 不过作为一个算法 xff0c 我感觉还是有必要研究一下的 我主要的参考资料是 算法导论 的33 3和这个博客 代码在这里 xff0
  • 1

    stage 1 xff1a 尝试直接使用Adobe acrobat xff0c foxit阅读器 xff0c 以及CAJ等PDF阅读器 xff0c 尝试使用CAJ是因为CAJ有文字识别功能 xff0c 但是对于加密的文档 xff0c 依然是
  • Python自动化备份系统及网站

    随着目前IT迅猛的发展 xff0c 自动化运维对于Linux运维人员也越来越重要 xff0c 传统的运维方式靠大量的人力 xff0c 现在也逐渐转向自动化运维 xff0c 我们常见的跟自动化有关的软件有哪些呢 今天我们来简单列举一下 xff
  • AI 黑箱难题怎么破?基于神经网络模型的算法使机器学习透明化

    编者按 xff1a 人们可以训练人工智能 xff08 AI xff09 和机器人完成任务 xff0c 但整个过程在黑箱中运作 我们并不知道 AI 和机器人是如何决策的 一家名为 OptimizingMind 的初创公司想要解决这个问题 这篇
  • 技术面试介绍

    内容 xff1a 1 技术面试的形式 2 技术面试的大致环节 3 技术面试应具备的素质 4 技术面试的经验建议 参考 xff1a 剑指offer 第二版 第一章 Java程序员面试笔试宝典 第一章 第二章 1 技术面试的形式 技术面试大致上
  • 今天是 Java 诞生日,Java 24 岁了!

    2019独角兽企业重金招聘Python工程师标准 gt gt gt 今天是 Java 诞生日 xff0c Java 今年 24 岁了 xff0c 比栈长还年轻 还有得搞 xff0c 别慌 xff01 作为一名Java语言的学习者 xff0c
  • [原创]求两个经纬度之间的距离

    经常要根据两个经纬度值 求它们之间的距离 delphi实现代码 xff1a 求两个经纬度之间的距离 function Distince const lon1 lat1 lon2 lat2 double double var alpha1 a
  • cmake的命令execute_process

    execute process COMMAND lt cmd1 gt args1 COMMAND lt cmd2 gt args2 WORKING DIRECTORY lt directory gt TIMEOUT lt seconds g
  • php 输出数组内容_php数组怎么输出

    PHP数组的输出方式有两种 xff1a print r 函数和var dump 函数 1 print r 利用 print r 函数可以打印输出整个数组内容及结构 xff0c 按照一定格式显示键和元素 注意 print r 函数不仅是只用于
  • VNC常用操作及常见问题解决办法汇总

    VNC登录用户缺省是root xff0c 但在安装oracle时必须用oracle用户的身份登录 xff0c 下面我们就以oracle为例说明如何配置VNC xff0c 从而可以使用不同的用户登录到主机 步骤描述如下 xff1a 步骤一 x
  • Xsens 在ROS环境下读取数据

    Xsens 在ROS环境下读取数据 1 Xsens 参数配置2 Xsens ROS环境下读取数据2 1 安装ROS二进制包2 2 Xsens修改rule文件2 3 启动节点 参考资料 1 Xsens 参数配置 软件可以在官网上进行下载 1

随机推荐

  • 交换机***查询篇

    如何确定 类型 当设备遭受 时 xff0c 通常伴随着如下现象 xff1a 用户无法获取ARP 用户上线成功率较低 用户无法访问网络 l严重时可能导致设备上所有用户都无法正常访问网络 当大量用户或固定某个端口下的所有用户出现上述现象时 xf
  • tomcat部署war包访问显示404

    在eclipse导出的maven项目war包 xff0c 放到tomcat下启动 xff0c 顺利启动且无报错 xff0c 但是浏览器访问该项目时显示404 原因 xff1a 未在server xml中配置这几个项目 xff0c 导致服务器
  • Pycharm: 代码跳转如何回退 (小技巧)

    背景 玩Python已经有段时间了 一般都是通过vim和Pycharm来开发 真心觉得这两个是神器 Vim神器暂且不说 今天来分享Pycharm的一个小技巧 用Pycharm的童鞋都知道 它有个跳转的功能 可以让我们在想深入了解某个函数 库
  • 最近沉迷美女图片无法自拔,所以我决定用PHP扒海量妹子图

    为什么80 的码农都做不了架构师 xff1f gt gt gt 学习PHP 43 MySQL制作WEB应用有一阵子了 xff0c 没有上过学所以只能学习到CURD的地步 最近对国产美女图片 私房写真特别感兴趣 xff0c 什么周妍希 刘飞儿
  • elementui的loading啊。。。踩坑了。。。

    为什么80 的码农都做不了架构师 xff1f gt gt gt 总结如下 xff1a 1 elementui的loading其实是fullscreen才是全局唯一 xff0c 不然会Loading service一次创建一次实例 2 ele
  • a padding to disable MSIE and Chrome friendly error page 填充禁用MSIE铬友好的错误页面

    一个网页在用户登录后 xff0c 应该自动刷新后 xff0c 显示登录用户信息 xff0c 但是没有自动刷新反而报错 xff0c 手动刷新后显示正常 显示如下 xff1a 检查代码 xff1a 可能原因 xff1a 文件读写权限 权限和用户
  • 边缘检测:Canny算子,Sobel算子,Laplace算子

    1 canny算子 Canny边缘检测算子是John F Canny于 1986 年开发出来的一个多级边缘检测 算法 更为重要的是 Canny 创立了边缘检测计算理论 xff08 Computational theory ofedge de
  • ProtocolException : 已超过传入消息(65536)的最大消息大小配额。

    SilverLight调用WCF xff0c 提交的是一个List lt Linq2SqlEntity gt xff1b 当List中数据量不大的时候 xff0c 不会报错 xff1b 当数据量稍微大一点儿 xff0c 就会出现这个错误 发
  • 最简单的限制edit输入

    procedure TForm1 Edt NumKeyPress Sender TObject var Key Char begin If not key in 48 57 then begin key 61 0 ShowMessage 3
  • 构建安全的数据访问-异常管理(八)

    异常条件可能会由配置错误 代码中的错误或恶意输入引起 如果没有正确的异常管理 xff0c 这些条件可能会透露有关数据源位置和特性的敏感信息 xff0c 以及有价值的连接详细信息 下面的建议适用于数据访问代码 xff1a 捕获和记录 ADO
  • 开源自主导航小车MickX4(四)底盘URDF模型

    开源自主导航小车MickX4 xff08 四 xff09 底盘URDF模型 1 底盘URDF模型1 1 URFD语法1 2 基于URDF语法绘制机器人1 3 URDF文件加载stl模型 2 绘制机器人URDF模型参考资料 1 底盘URDF模
  • 中国移动5G测试路线图

    中国移动通信研究院首席科学家易芝玲博士表示 xff0c 中国移动5G技术更新的目标是实现提供高分辨率视频的传输 xff0c 2020年中国移动将推出真正的5G商用服务 谈到中国移动目前5G测试的进展 xff0c 易芝玲介绍说 xff0c 中
  • sphinx+reStructuredText制作文档

    1 spinx简介 Sphinx 是一种文档工具 xff0c 它可以令人轻松的撰写出清晰且优美的文档 由 Georg Brandl 在BSD 许可证下开发 新版的Python文档 就是由Sphinx生成的 xff0c 并且它已成为Pytho
  • C\C++程序员面试宝典---持续整理

    1 C 43 43 中有哪几种基本数据类型 C 43 43 中的基础数据类型分为3种 xff1a 整数型 xff0c 浮点型 xff0c void型 转载于 https www cnblogs com yangyuqing p 103741
  • 理解 Linux 网络栈(1):Linux 网络协议栈简单总结

    本系列文章总结 Linux 网络栈 xff0c 包括 xff1a xff08 1 xff09 Linux 网络协议栈总结 xff08 2 xff09 非虚拟化Linux环境中的网络分段卸载技术 GSO TSO UFO LRO GRO xff
  • PHP开发中常见的设计模式

    一 工厂模式 工厂模式是我们最常用的实例化对象模式 xff0c 是用工厂方法代替new操作的一种模式 使用工厂模式的好处是 xff0c 如果你想要更改所实例化的类名等 xff0c 则只需更改该工厂方法内容即可 xff0c 不需逐一寻找代码中
  • 监控摄像头清晰度(分辨率)介绍

    常见的视频图像画质有以下几种 xff1a QCIF xff1a 176 144 xff1b CIF xff1a 352 288 xff1b VCD画质 2CIF xff1a 704 288 xff1b 4CIF D1 xff1a 704 5
  • Sublime Text怎么快速建立一个html5页面模板

    在编辑器中输入一个半角英文的感叹号 xff08 xff09 然后按下TAB键
  • 移动硬盘格式化(pc和mac共用)-菜鸟级解决方案[转]

    用pc的时候买了一个320G的移动硬盘 xff0c 从来没考虑过什么格式化的问题 xff0c 插上就用了 后来接触mac才发现pc和mac在移动存储设备的格式化上还是有不少冲突的 如果你的移动硬盘mac上不能修改 xff0c 或者pc上找不
  • 开源自主导航小车MickX4(五)gmapping建图

    开源自主导航小车MickX4 xff08 五 xff09 gmapping建图 1 激光雷达驱动2 3D点云到2D点云的转换3 gmapping 建图3 1 安装 gmapping库3 2 配置 gmapping3 3 启动 gmappin