Gmapping各个参数的说明-不定期更新(后面更新解析部分)

<launch>
    <arg name="scan_topic" default="scan" />
<!--
    static_transform_publisher 
    x y z yaw pitch roll 
    frame_id child_frame_id 
    period_in_ms

    Publish a static coordinate transform to tf using an x/y/z offset in meters and yaw/pitch/roll in radians. (yaw is rotation about Z, pitch is rotation about Y, and roll is rotation about X). The period, in milliseconds, specifies how often to send a transform. 100ms (10hz) is a good value.
-->

<!--
    static_transform_publisher 
    x y z qx qy qz qw 
    frame_id child_frame_id  
    period_in_ms

    Publish a static coordinate transform to tf using an x/y/z offset in meters and quaternion. The period, in milliseconds, specifies how often to send a transform. 100ms (10hz) is a good value.
-->

        <!--TODO-->
<!--
    <node pkg="tf" type="static_transform_publisher" name="link1_broadcaster" args="0.265 0.0 0.075 0 0 0 chassis laser 50" />
-->

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

        <!--里程计坐标系-->
        <param name="odom_frame" value="/odom"/>
        <!--param name="odom_frame" value="/vesc/odom"/-->

        <!--TODO-->
        <param name="base_frame" value="base_link"/> <!--机器人底盘坐标系基框架,附带在移动底盘的框架,原点-->
        <param name="map_frame" value="map"/> <!--地图坐标系地图框架,附带在地图上的框架-->

        <!--TODO-->
        <!--地图更新速度,秒0.01-->
        <param name="map_update_interval" value="5.0"/>
        <!-- Set maxUrange < actual maximum range of the Laser -->
        <!--地图更新频率-->

       <!--TODO--> 
        <param name="maxRange" value="12.0"/>
        <param name="maxUrange" value="10.0"/>  <!--探测最大可用范围,即光束能到达的范围。default: 80.0-->

        <param name="sigma" value="0.05"/>      <!--endpoint匹配标准差-->

        <!--TODO--> 
        <param name="kernelSize" value="3"/>    <!-- used to be 1-->
        <!--用于查找对应的kernel size-->

        <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="lskip" value="0"/>         <!--每次扫描跳过的光束数.-->

        <param name="srr" value="0.01"/>        <!--平移时里程误差作为平移函数(rho/rho)-->
        <param name="srt" value="0.02"/>        <!--平移时的里程误差作为旋转函数 (rho/theta)-->
        <param name="str" value="0.01"/>        <!--旋转时的里程误差作为平移函数 (theta/rho)-->
        <param name="stt" value="0.02"/>        <!--旋转时的里程误差作为旋转函数 (theta/theta)-->

        <!--线速度角速度在地图的更新-->
        <param name="linearUpdate" value="0.5"/>    <!--机器人每旋转这么远处理一次扫描-->
        <param name="angularUpdate" value="0.436"/> <!--Process a scan each time the robot rotates this far-->
        <param name="temporalUpdate" value="-1.0"/> <!--如果最新扫描处理比更新慢,则处理1次扫描。该值为负数时候关闭基于时间的更新-->

        <param name="resampleThreshold" value="0.5"/>   <!--基于重采样门限的Neff-->

        <!--TODO-->
        <!--滤波器中粒子数目-->
        <param name="particles" value="8"/> <!-- used to be 80-->

        <!--地图初始尺寸-->
        <param name="xmin" value="-50.0"/><!-- used to be -1.0-->
        <param name="ymin" value="-50.0"/><!-- used to be -1.0-->
        <param name="xmax" value="50.0"/><!-- used to be 1.0-->
        <param name="ymax" value="50.0"/><!-- used to be 1.0-->

        <!--地图分辨率-->
        <param name="delta" value="0.05"/>

        <!--于似然计算的平移采样距离-->
        <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)"/>

        <!--
            ~transform_publish_period (float, default: 0.05),变换发布时间间隔.
            ~occ_thresh (float, default: 0.25),栅格地图栅格值 (i.e., set to 100 in the resultingsensor_msgs/LaserScan).
            ~maxRange (float),传感器最大范围。如果在传感器距离范围内没有障碍物应该在地图上显示为自由空间。 maxUrange < 真实传感器最大距离范围 <= maxRange.
        -->
        <!-- 
            需要的tf转换:
                →base_link,通常是一个固定值,通过 robot_state_publisher, 或者 tf static_transform_publisher.周期性广播
                base_link →odom,通常由里程计系统提供
            提供的tf转换:
                 map → odom,地图坐标系中机器人当前姿态估计
        -->
        <!-- 
            particles (int, default: 30) :
            	gmapping算法中的粒子数,因为gmapping使用的是粒子滤波算法,粒子在不断地迭代更新,所以选取一个合适的粒子数可以让算法在保证比较准确的同时有较高的速度。
            minimumScore (float, default: 0.0) :
            	最小匹配得分,这个参数很重要,它决定了对激光的一个置信度,越高说明对激光匹配算法的要求越高,激光的匹配也越容易失败而转去使用里程计数据,而设的太低又会使地图中出现大量噪声,所以需要权衡调整。
        -->
    </node>
</launch>

  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值