Navigation包中的move_base和amcl实现自动驾驶

安装导航定位包,navigation: 
    sudo apt-get install ros-indigo-navigation
由于导航包在/cmd_val下发布的移动数据加速度会过于不友好,所以我们需要对速度做平滑处理,其实就是控制加速,一般通过滤波即可实现,在此我们采用turtlebot的平滑包即可安装平滑包yocs_velocity_smoother,具体的平滑算法和输入切换请自己阅读源码 :
    sudo apt-get install ros-indigo-yocs-velocity-smoother
在小车的运动控制的launch中如下添加:
 <!-- velocity smoother -->
  <include file="$(find yocs_velocity_smoother)/launch/velocity_smoother.launch">
  </include>


导航包(move_base)和定位(amcl)的启动文件:nav_amcl.launch
<launch
  <param name="use_sim_time" value="false" />
  <!-- Set the name of the map yaml file: can be overridden on the command line. -->
  <arg name="map" default="map.yaml" />
  <!--node name="map_odom" pkg="tf" type="static_transform_publisher" args="0 0 0 0 0 0 map odom 50"/-->
  <!-- Run the map server with the desired map -->
  <node name="map_server" pkg="map_server" type="map_server" args="$(find odom_tf_package)/maps/$(arg map)"/>
  <!-- The move_base node -->
  <include file="$(find odom_tf_package)/launch/move_base_amcl.launch" />
  <!--add Fire up AMCL-->
  <include file="$(find odom_tf_package)/launch/tb_amcl.launch" />
</launch>


move_base_amcl.launch:
<launch>

  <node pkg="move_base" type="move_base" respawn="false" name="move_base" output="screen" clear_params="true">
    <rosparam file="$(find odom_tf_package)/config/costmap_common_params.yaml" command="load" ns="global_costmap" />
    <rosparam file="$(find odom_tf_package)/config/costmap_common_params.yaml" command="load" ns="local_costmap" />
    <rosparam file="$(find odom_tf_package)/config/local_costmap_params.yaml" command="load" />
    <rosparam file="$(find odom_tf_package)/config/global_costmap_params.yaml" command="load" />
    <rosparam file="$(find odom_tf_package)/config/base_local_planner_params.yaml" command="load" />
  </node>
  
</launch>


tb_amcl.launch:
<launch>

  <arg name="use_map_topic" default="false"/>
  <arg name="scan_topic" default="scan"/>
  <node pkg="amcl" type="amcl" name="amcl" clear_params="true">
    <param name="use_map_topic" value="$(arg use_map_topic)"/>
    <!-- Publish scans from best pose at a max of 10 Hz -->
    <param name="odom_model_type" value="diff"/>
    <param name="odom_alpha5" value="0.1"/>
    <param name="gui_publish_rate" value="10.0"/>
    <param name="laser_max_beams" value="60"/>
    <param name="laser_max_range" value="12.0"/>
    <param name="min_particles" value="500"/>
    <param name="max_particles" value="2000"/>
    <param name="kld_err" value="0.05"/>
    <param name="kld_z" value="0.99"/>
    <param name="odom_alpha1" value="0.2"/>
    <param name="odom_alpha2" value="0.2"/>
    <!-- translation std dev, m -->
    <param name="odom_alpha3" value="0.2"/>
    <param name="odom_alpha4" value="0.2"/>
    <param name="laser_z_hit" value="0.5"/>
    <param name="laser_z_short" value="0.05"/>
    <param name="laser_z_max" value="0.05"/>
    <param name="laser_z_rand" value="0.5"/>
    <param name="laser_sigma_hit" value="0.2"/>
    <param name="laser_lambda_short" value="0.1"/>
    <param name="laser_model_type" value="likelihood_field"/>
    <!-- <param name="laser_model_type" value="beam"/> -->
    <param name="laser_likelihood_max_dist" value="2.0"/>
    <param name="update_min_d" value="0.25"/>
    <param name="update_min_a" value="0.2"/>

    <param name="odom_frame_id" value="odom"/>

    <param name="resample_interval" value="1"/>
    <!-- Increase tolerance because the computer can get quite busy -->
    <param name="transform_tolerance" value="1.0"/>
    <param name="recovery_alpha_slow" value="0.0"/>
    <param name="recovery_alpha_fast" value="0.0"/>
    <remap from="scan" to="$(arg scan_topic)"/>
  </node>
</launch>


4.导航的配置参数如下:
base_local_planner_params.yaml

    controller_frequency: 2.0
    recovery_behavior_enabled: false
    clearing_rotation_allowed: false

    TrajectoryPlannerROS:
       max_vel_x: 0.3
       min_vel_x: 0.05
       max_vel_y: 0.0  # zero for a differential drive robot
       min_vel_y: 0.0
       min_in_place_vel_theta: 0.5
       escape_vel: -0.1
       acc_lim_x: 2.5
       acc_lim_y: 0.0 # zero for a differential drive robot
       acc_lim_theta: 3.2

       holonomic_robot: false
       yaw_goal_tolerance: 0.1 # about 6 degrees
       xy_goal_tolerance: 0.15  # 10 cm
       latch_xy_goal_tolerance: false
       pdist_scale: 0.8
       gdist_scale: 0.6
       meter_scoring: true

       heading_lookahead: 0.325
       heading_scoring: false
       heading_scoring_timestep: 0.8
       occdist_scale: 0.1
       oscillation_reset_dist: 0.05
       publish_cost_grid_pc: false
       prune_plan: true

       sim_time: 2.5
       sim_granularity: 0.025
       angular_sim_granularity: 0.025
       vx_samples: 8
       vy_samples: 0 # zero for a differential drive robot
       vtheta_samples: 20
       dwa: true
       simple_attractor: false


costmap_common_params.yaml

    obstacle_range: 2.5
    raytrace_range: 3.0
    robot_radius: 0.30
    inflation_radius: 0.15
    max_obstacle_height: 0.6
    min_obstacle_height: 0.0
    observation_sources: scan
    scan: {data_type: LaserScan, topic: /scan, marking: true, clearing: true, expected_update_rate: 0}

global_costmap_params.yaml
    global_costmap:
       global_frame: /map
       robot_base_frame: /base_link
       update_frequency: 1.0
       publish_frequency: 0
       static_map: true
       rolling_window: false
       resolution: 0.01
       transform_tolerance: 0.5
       map_type: costmap


local_costmap:
   global_frame: /odom
   robot_base_frame: /base_link
   update_frequency: 1.0
   publish_frequency: 1.0
   static_map: false
   rolling_window: true
   width: 6.0
   height: 6.0
   resolution: 0.01
   transform_tolerance: 0.5
   map_type: costmap

四,准备好以上所有的启动文件和配置参数后,我们开始创建地图和导航,
1.创建地图:
roslaunch ros_car_py ros_car_py.launch   //启动地盘控制器
roscd odom_tf_package/maps/
rosrun map_server map_saver -f map
然后会产生以下地图文件
map.pgm  map.yaml


2.开始导航
roslaunch ros_car_py nav_amcl.launch map:=map.yaml
然后指定导航目标,因为我的TF变换主要是里程计更新的,车体打滑或者地盘电机震荡都会积累误差,
所以我们必须添加视觉里成计或者闭环检测。
在rviz中点击菜单栏的2D Nav Goal,可以帮助我们设置导航的目标点
 

地区行业网址导航程序系统简介: 1、真正适用于针对专业的"地方导航"/"行业导航"的开源程序,基于SDCMS1.31内核,程序体积小巧、采用ASP ACCESS构架二次开发适用于导航网站使用的程序.网页模版清新简洁。全功能无任何限制,绿色实用,功能不算强大,但很实用。 2、模板采用html css架构,兼容世界之窗/360安全/360极速/FF/IE789及以上等主流浏览器. 3、主页模板主体布局清晰实用,分为三大部分:(1).国内名站(带数据) - 最主流网民最常用的网站.(2).本地网站(程序发布时无数据,需站长添,目的是方便其他地区站长使用) - 本地网民或行业用户最常访问的实用网站.(3).通用网站(带数据) - 分类列出网民经常访问的网站. 4、网站前后台分离,安全稳定,防注入功能,数据库已做安全防下载处理。程序绝无后门无病毒,解压后数据自上传到主目录和任何二级目录均可以正常使用。 5、网站预留三个广告位,分别为右上,下中,左下,合理简洁.注:本站仅预留了广告图片位置,并无广告代码.在网站后台自行修改JS代码就可更新广告内容. 6、自带了ASP调试程序,双击打开即可测试.程序会在系统托盘处,如关闭浏览器后要重新打开,请在托盘处右键"重启服务"或退出,重新运行. 7、网站自动化发布区域与固定区域分离,也就是SDCMS程序的"碎片"功能,减少了服务器压力.程序中的所有网址数据均可自由方便的修改. 8、全站可采用动态、伪静态、纯静态html方式。默认为动态模式方便调试,建议调试完毕后改为静态生成,更加安全快速. 9、分类页包含个性化的title、meta,易于搜索引擎收录! 10、网站分类齐全,网址收录比较全面(程序发布时已删除淮安本地网址,目的是方便其他地区网友使用)。 地区行业网址导航程序源码特点: 1、本程序模板布局非常适用"地域特色","行业特色"网站导航,这也是未来导航发展趋势之一. 2、程序后台非常简洁实用,上手容易.导航类别栏目无限多级分类,自由添加。 3、模板简洁美化大方,模板代码已做全面优化清晰无垃圾,加载速度飞快. 4、自带四套共20款600IT.COM原创背景可供用户自由"更换皮肤",新颖有趣. 按钮在网站右上角 地区行业网址导航程序注意: 1.解开本程序包,上传到支持ASP的服务器上。 2.后台登陆地址:http://您的网址/admin/ 3.用户和密码均为admin  ---正式使用时请站长自行修改登陆密码. 4.数据库所在目录:Data  ---已经做了防下载处理。 5.网站配置文件:Inc/Const.asp  ---需要修改数据库名的站长请在此文件中改,此为全站配置文件请小心操作. 地区行业网址导航程序前台页面  地区行业网址导航程序后台管理 后台登陆地址:http://您的网址/admin/ 用户和密码均为admin 后台页面: 相关阅读 同类推荐:网址导航源码
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值