[ROS]Setup and Configuration of the Navigation Stack on a Robot

本贴最后更新于 2998 天前,其中的信息可能已经时过境迁

####前言
本文一步步的介绍如何在运行的机器人上一步步实现导航。包含的主题包括:发送坐标转换的 tf,发布里里程计信息,通过 ROS 发布激光传感器数据和基本的导航包配置。

####1.机器人建立

导航包假设已经部分配置好能够跑动。上面的图解展示了这个配置。白色的组件是必须的组件,并且已经实现了;灰色的组件是可选的组件,并且也已经实现了;蓝色的组件是必须为每一个具体的机器人平台创建的。导航包的预需求部分(以及说明如何满足每一个需求)在下文中提供。

#####1.1ROS

导航包默认机器人使用 ROS,关于如何安装在机器人上安装 ROS 需要查找 ROS 文档。

#####1.2.转换配置 (其他平台)

导航报需要机器人发布使用 tf 转换后的坐标系之间关系的信息。关于如何建立这种配置的详细教程参考:http://wiki.ros.org/navigation/Tutorials/RobotSetup/TF

#####1.3.传感器信息 (源自传感器)

导航包使用传感器收集的信息进行避障,假设这些传感器通过 ROS 发布 sensor_msgs/LaserScan 或者 sensor_msgs/PointCloud 信息。关于通过 ROS 发布的这些信息,参考:http://wiki.ros.org/navigation/Tutorials/RobotSetup/Sensors。当然了,已经有一部分传感器已经有了 ROS 驱动包含了这一步骤。已支持的传感器和相关的驱动链接如下:
######SCIP2.2-compliant Hokuyo Laser Devices as well as the Hokuyo Model 04LX, 30LX - urg_node(http://wiki.ros.org/urg_node)
######SICK LMS2xx Lasers - sicktoolbox_wrapper(http://wiki.ros.org/sicktoolbox_wrapper)

#####1.4.里程信息 (来自里程计)

导航包需要使用 tf 和 nav_msgs/Odometry 信息发布的里程计信息。关于通过 ROS 发布里程计信息的教程参考:http://wiki.ros.org/navigation/Tutorials/RobotSetup/Odom。支持里程计的平台和链接参考:
######Videre Erratic: erratic_player(http://wiki.ros.org/erratic_player)
######PR2: pr2_mechanism_controllers(http://wiki.ros.org/pr2_mechanism_controllers)

#####1.5.底盘控制

导航包假设 它可以使用"cmd_vel"主题上发布的在底盘坐标系上的 geometry_msgs/Twist 消息发布速度命令。这意味着必须有一个节点订阅“cmd_vel”主题,“cmd_vel”能公布(vx, vy, vtheta) <==> (cmd_vel.linear.x, cmd_vel.linear.y, cmd_vel.angular.z)速度以及转换他们为运动命令并发送到移动底盘。支持底盘控制平台以及相关驱动的链接如下:
######Videre Erratic: erratic_player
######PR2: pr2_mechanism_controllers

#####1.6.建图(map_server)

导航包需要地图用来操作,但是在本教程假设已经有了一个地图。关于详细的如何在具体环境中创建地图参考:http://wiki.ros.org/slam_gmapping/Tutorials/MappingFromLoggedData。

####2.导航包的建立

本节描述如何在机器人上建立和配置导航包。假设上文描述的建立机器人的需求已经得到满足。特别地,这也意味着机器人必须使用 tf 发布坐标系信息,所有传感器发布的 sensor_msgs/LaserScan 或者 sensor_msgs/PointCloud 将被导航包使用,使用 tf 和 sensor_msgs.LaserScan 发布的里程计信息同样通过速度命令发送到底盘。如果机器人不满足这些需求,查看上文的说明并完善。

#####2.1 创建 package

本教程的第一步就是创建一个 package,我们将用它来保存导航包的所有的配置和 launch 文件。上述机器人建立步骤描述的满足需要的所有包的依赖对于 move_base package 也一样,它包含了实现导航包的高等级的接口。所以,选择 package 的保存位置,运行如下命令:

catkin_create_pkg my_robot_name_2dnav move_base my_tf_configuration_dep my_odom_configuration_dep my_sensor_configuration_dep

#####2.2.创建 launch 配置文件

既然我们已经有了保存配置和 launch 文件的工作空间,我们将创建一个 roslaunch 文件建立机器人需要的所有硬件和转换的发布。打开偏好的编辑器,把下面的片段复制到 my_robot_configuration.launch 文件中,这里可以将具体的机器人平台名字替换掉 my_robot。同样的,下面也有一些类似的改变。

<launch>
  <node pkg="sensor_node_pkg" type="sensor_node_type" name="sensor_node_name" output="screen">
    <param name="sensor_param" value="param_value" />
  </node>

  <node pkg="odom_node_pkg" type="odom_node_type" name="odom_node" output="screen">
    <param name="odom_param" value="param_value" />
  </node>

  <node pkg="transform_configuration_pkg" type="transform_configuration_type" name="transform_configuration_name" output="screen">
    <param name="transform_configuration_param" value="param_value" />
  </node>
</launch>

好了,现在已经有了一个 launch 文件的模板,现在我们需要根据具体的机器人进行填充。下文将介绍具体介绍每一个区域需要更改的内容。

<launch>
  <node pkg="sensor_node_pkg" type="sensor_node_type" name="sensor_node_name" output="screen">
    <param name="sensor_param" value="param_value" />

在本区域中,我们将创建任何机器人需要导航用到的传感器。用实际使用的传感器 package 名替换掉"sensor_node_pkg","sensor_node_type"是传感器驱动的类型,"sensor_node_name"是给传感器节点取的名字,"sensor_param"是给节点设置的参数。注意,如果有多传感器数据需要发送到导航包,那么必须为所有传感器建立节点。

  <node pkg="odom_node_pkg" type="odom_node_type" name="odom_node" output="screen">
    <param name="odom_param" value="param_value" />
  </node>

上述代码建立了底盘的里程计节点。代码中的 pkg、type、name、param 等参数根据具体的机器人平台相关。

  <node pkg="transform_configuration_pkg" type="transform_configuration_type" name="transform_configuration_name" output="screen">
    <param name="transform_configuration_param" value="param_value" />
  </node>

上述代码创建了机器人的转换配置。代码中的参数根据具体的参数进行修改。

#####2.3.Costmap Configuration (local_costmap) & (global_costmap)

导航包使用 2 个 costmap 记录世界参考系中的障碍信息。一个用来全局路径规划,同时创建整体环境的长期规划,另一个用来局部规划和避障。有部分是两个 costmap 共同的配置选项,也有部分是单独的。因此,下文将有 3 个部分来介绍相关配置:公共配置选项,全局配置选项,局部配置选项。
注意:下文只是介绍了一些基本的配置选项,关于更多的配置选项,参考:http://wiki.ros.org/costmap_2d。

######2.3.1.Common Configuration (local_costmap) & (global_costmap)

导航包使用 costmap 保存世界参考系中的障碍物信息。为了正确的完成这个目标,我们需要支出在传感器主题中指出 costmap 用来监听更新。下面我们创建 costmap_common_params.yaml 文件然后复制下面的内容:

obstacle_range: 2.5
raytrace_range: 3.0
footprint: [[x0, y0], [x1, y1], ... [xn, yn]]
#robot_radius: ir_of_robot
inflation_radius: 0.55

observation_sources: laser_scan_sensor point_cloud_sensor

laser_scan_sensor: {sensor_frame: frame_name, data_type: LaserScan, topic: topic_name, marking: true, clearing: true}

point_cloud_sensor: {sensor_frame: frame_name, data_type: PointCloud, topic: topic_name, marking: true, clearing: true}

接下来将详细的解析上述代码;

obstacle_range: 2.5
raytrace_range: 3.0

这个参数集合给定了加进 costmap 中的障碍信息的阈值。"obstacle_range"决定范围传感器读取到的最大数据导致在 costmap 中加入障碍。这里,我们设置的是 2.5 米,这意味着机器人将仅仅更新 costmap 中的底盘的障碍信息在 2.5 米内。"raytrace_range"参数决定给定传感器读取的光线追踪自由空间。设置它为 3 米表示机器人通过给定的传感器读取的数据将尝试清除它面前的空间到 3 米外。

footprint: [[x0, y0], [x1, y1], ... [xn, yn]]
#robot_radius: ir_of_robot
inflation_radius: 0.55

这里我们设置机器人的 footprint 和机器人的半径(如果是圆的话)。如果要指定 footprint,机器人的中心假定为(0,0,0,0)以及指定顺时针和逆时针方向都能被支持。

observation_sources: laser_scan_sensor point_cloud_sensor

"observation_sources"参数定义指令了一个传感器列表,这些传感器将传递信息给由空间分隔的 costmap。每一个传感器在下面的一行代码定义。

laser_scan_sensor: {sensor_frame: frame_name, data_type: LaserScan, topic: topic_name, marking: true, clearing: true}

上述的一行设置 observation_sources 中传感器关注的参数,本示例定义了 laser_scan_sensor 作为示例。
"frame_name"是传感器的坐标系的名字,"data_type"必须被设置为 LaserScan 或者 PointCloud,取决于使用了哪种消息的的主题,"topic_name"必须设置为传感器发布数据的主题的名字。"marking" 和 "clearing"决定传感器是否被用来增加障碍信息到 costmap 中,从 costmap 清除障碍信息或者两者都是。

######2.3.2.Global Configuration (global_costmap)

我们将创建 global_costmap_params.yaml 文件保存全局 costmap 的具体配置选项。

global_costmap:
  global_frame: /map
  robot_base_frame: base_link
  update_frequency: 5.0
  static_map: true

"global_frame"参数定义 costmap 运行在哪一个坐标系,这里设置的是/map 参考系."robot_base_frame" 参数定义了 costmap 与底盘关联的坐标系。"update_frequency"参数定义 costmap 更新的频率,单位是 HZ。 "static_map"参数决定 costmap 是否以 map server 提供的 mao 为基础初始化自身。如果不是使用已有的地图或者 map server,设置这个参数为 false。

######2.3.3.Local Configuration (local_costmap)

我们将创建 local_costmap_params.yaml 文件保存局部 costmap 的具体配置选项:

local_costmap:
  global_frame: odom
  robot_base_frame: base_link
  update_frequency: 5.0
  publish_frequency: 2.0
  static_map: false
  rolling_window: true
  width: 6.0
  height: 6.0
  resolution: 0.05

"global_frame", "robot_base_frame", "update_frequency",以及 "static_map" 的含义与上文的全局配置参数含义相同."publish_frequency"定义了 costmap 发布可视化信息的速率,单位是 HZ。"rolling_window"参数表示是否以机器人为中心,是则机器人始终在地图的中央。"width," "height," 和"resolution"设置 costmap 的宽度(米)、长度(米)、分辨率(米/格)。值得注意的是最好设置 grid 的分辨率和 static map 的分辨率不同,但是大多数的时候还是倾向于设置成一样。

######2.3.4.Full Configuration Options

最小配置应该要能启动和运行,对于 costmap 的更多的可用配置选项参考:http://wiki.ros.org/costmap_2d。
#####2.4.Base Local Planner Configuration
base_local_planner 响应速度计算命令并发送到机器人移动底盘用于更高级别的规划。我们需要根据机器人的规则去设置一些配置参数。新建 base_local_planner_params.yaml 文件然后复制下面的内容:

注意:这里这配置了一些基本的路径规划配置参数。更多的参考:http://wiki.ros.org/base_local_planner。

TrajectoryPlannerROS:
  max_vel_x: 0.45
  min_vel_x: 0.1
  max_vel_theta: 1.0
  min_in_place_vel_theta: 0.4

  acc_lim_theta: 3.2
  acc_lim_x: 2.5
  acc_lim_y: 2.5

  holonomic_robot: true

上述的第一部分参数定义了机器人的速度限制。第二部分定义了机器人的加速度限制。

#####2.5.Creating a Launch File for the Navigation Stack

现在我们已经创建并编写好了所有需要的配置文件,现在需要把所有的文件在一个 launch 文件里面配置好。新建 move_base.launch 文件,然后复制以下内容:

<launch>
  <master auto="start"/>

  <!-- Run the map server -->
  <node name="map_server" pkg="map_server" type="map_server" args="$(find my_map_package)/my_map.pgm my_map_resolution"/>

  <!--- Run AMCL -->
  <include file="$(find amcl)/examples/amcl_omni.launch" />

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

仅需要的改变就是需要将 map server 指向你创建的地图,改变"amcl_omni.launch" 为 "amcl_diff.launch",如果你有不同的机器人驱动。关于如何创建地图,参考:http://wiki.ros.org/slam_gmapping/Tutorials/MappingFromLoggedData。

#####2.6.AMCL Configuration (amcl)

AMCL 有多个配置选项会影响定位的性能,更多的请参考:amcl documentation.http://wiki.ros.org/amcl

####3.Running the Navigation Stack

现在我们已经创建好了一切,现在可以运行导航包了。执行:

终端 1:

roslaunch my_robot_configuration.launch

终端 2:

roslaunch move_base.launch

可以看到导航包已经运行起来了。
关于通过图像化界面查看发送到导航包的信息查看:http://wiki.ros.org/navigation/Tutorials/Using%20rviz%20with%20the%20Navigation%20Stack。如果要用代码替代发送信息,参看:http://wiki.ros.org/navigation/Tutorials/SendingSimpleGoals。

####4.Troubleshooting

关于导航包使用中遇到的问题,参考:http://wiki.ros.org/navigation/Troubleshooting

######关键字:mobile platform setup, robot setup, setup robot, getting started with mobile robot

  • ROS
    23 引用 • 2 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • Swagger

    Swagger 是一款非常流行的 API 开发工具,它遵循 OpenAPI Specification(这是一种通用的、和编程语言无关的 API 描述规范)。Swagger 贯穿整个 API 生命周期,如 API 的设计、编写文档、测试和部署。

    26 引用 • 35 回帖 • 1 关注
  • 工具

    子曰:“工欲善其事,必先利其器。”

    286 引用 • 729 回帖
  • 安全

    安全永远都不是一个小问题。

    199 引用 • 816 回帖 • 1 关注
  • Oracle

    Oracle(甲骨文)公司,全称甲骨文股份有限公司(甲骨文软件系统有限公司),是全球最大的企业级软件公司,总部位于美国加利福尼亚州的红木滩。1989 年正式进入中国市场。2013 年,甲骨文已超越 IBM,成为继 Microsoft 后全球第二大软件公司。

    105 引用 • 127 回帖 • 382 关注
  • H2

    H2 是一个开源的嵌入式数据库引擎,采用 Java 语言编写,不受平台的限制,同时 H2 提供了一个十分方便的 web 控制台用于操作和管理数据库内容。H2 还提供兼容模式,可以兼容一些主流的数据库,因此采用 H2 作为开发期的数据库非常方便。

    11 引用 • 54 回帖 • 654 关注
  • 周末

    星期六到星期天晚,实行五天工作制后,指每周的最后两天。再过几年可能就是三天了。

    14 引用 • 297 回帖 • 1 关注
  • CSDN

    CSDN (Chinese Software Developer Network) 创立于 1999 年,是中国的 IT 社区和服务平台,为中国的软件开发者和 IT 从业者提供知识传播、职业发展、软件开发等全生命周期服务,满足他们在职业发展中学习及共享知识和信息、建立职业发展社交圈、通过软件开发实现技术商业化等刚性需求。

    14 引用 • 155 回帖
  • Postman

    Postman 是一款简单好用的 HTTP API 调试工具。

    4 引用 • 3 回帖 • 3 关注
  • iOS

    iOS 是由苹果公司开发的移动操作系统,最早于 2007 年 1 月 9 日的 Macworld 大会上公布这个系统,最初是设计给 iPhone 使用的,后来陆续套用到 iPod touch、iPad 以及 Apple TV 等产品上。iOS 与苹果的 Mac OS X 操作系统一样,属于类 Unix 的商业操作系统。

    85 引用 • 139 回帖 • 1 关注
  • SSL

    SSL(Secure Sockets Layer 安全套接层),及其继任者传输层安全(Transport Layer Security,TLS)是为网络通信提供安全及数据完整性的一种安全协议。TLS 与 SSL 在传输层对网络连接进行加密。

    70 引用 • 193 回帖 • 431 关注
  • Sym

    Sym 是一款用 Java 实现的现代化社区(论坛/BBS/社交网络/博客)系统平台。

    下一代的社区系统,为未来而构建

    524 引用 • 4601 回帖 • 700 关注
  • Unity

    Unity 是由 Unity Technologies 开发的一个让开发者可以轻松创建诸如 2D、3D 多平台的综合型游戏开发工具,是一个全面整合的专业游戏引擎。

    25 引用 • 7 回帖 • 173 关注
  • Hibernate

    Hibernate 是一个开放源代码的对象关系映射框架,它对 JDBC 进行了非常轻量级的对象封装,使得 Java 程序员可以随心所欲的使用对象编程思维来操纵数据库。

    39 引用 • 103 回帖 • 709 关注
  • FFmpeg

    FFmpeg 是一套可以用来记录、转换数字音频、视频,并能将其转化为流的开源计算机程序。

    23 引用 • 32 回帖
  • LaTeX

    LaTeX(音译“拉泰赫”)是一种基于 ΤΕΧ 的排版系统,由美国计算机学家莱斯利·兰伯特(Leslie Lamport)在 20 世纪 80 年代初期开发,利用这种格式,即使使用者没有排版和程序设计的知识也可以充分发挥由 TeX 所提供的强大功能,能在几天,甚至几小时内生成很多具有书籍质量的印刷品。对于生成复杂表格和数学公式,这一点表现得尤为突出。因此它非常适用于生成高印刷质量的科技和数学类文档。

    12 引用 • 54 回帖 • 65 关注
  • 大疆创新

    深圳市大疆创新科技有限公司(DJI-Innovations,简称 DJI),成立于 2006 年,是全球领先的无人飞行器控制系统及无人机解决方案的研发和生产商,客户遍布全球 100 多个国家。通过持续的创新,大疆致力于为无人机工业、行业用户以及专业航拍应用提供性能最强、体验最佳的革命性智能飞控产品和解决方案。

    2 引用 • 14 回帖
  • Python

    Python 是一种面向对象、直译式电脑编程语言,具有近二十年的发展历史,成熟且稳定。它包含了一组完善而且容易理解的标准库,能够轻松完成很多常见的任务。它的语法简捷和清晰,尽量使用无异义的英语单词,与其它大多数程序设计语言使用大括号不一样,它使用缩进来定义语句块。

    543 引用 • 672 回帖 • 1 关注
  • OAuth

    OAuth 协议为用户资源的授权提供了一个安全的、开放而又简易的标准。与以往的授权方式不同之处是 oAuth 的授权不会使第三方触及到用户的帐号信息(如用户名与密码),即第三方无需使用用户的用户名与密码就可以申请获得该用户资源的授权,因此 oAuth 是安全的。oAuth 是 Open Authorization 的简写。

    36 引用 • 103 回帖 • 9 关注
  • CentOS

    CentOS(Community Enterprise Operating System)是 Linux 发行版之一,它是来自于 Red Hat Enterprise Linux 依照开放源代码规定释出的源代码所编译而成。由于出自同样的源代码,因此有些要求高度稳定的服务器以 CentOS 替代商业版的 Red Hat Enterprise Linux 使用。两者的不同在于 CentOS 并不包含封闭源代码软件。

    238 引用 • 224 回帖
  • Vue.js

    Vue.js(读音 /vju ː/,类似于 view)是一个构建数据驱动的 Web 界面库。Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。

    266 引用 • 665 回帖
  • SOHO

    为成为自由职业者在家办公而努力吧!

    7 引用 • 55 回帖 • 19 关注
  • Hadoop

    Hadoop 是由 Apache 基金会所开发的一个分布式系统基础架构。用户可以在不了解分布式底层细节的情况下,开发分布式程序。充分利用集群的威力进行高速运算和存储。

    86 引用 • 122 回帖 • 625 关注
  • TGIF

    Thank God It's Friday! 感谢老天,总算到星期五啦!

    287 引用 • 4484 回帖 • 669 关注
  • NGINX

    NGINX 是一个高性能的 HTTP 和反向代理服务器,也是一个 IMAP/POP3/SMTP 代理服务器。 NGINX 是由 Igor Sysoev 为俄罗斯访问量第二的 Rambler.ru 站点开发的,第一个公开版本 0.1.0 发布于 2004 年 10 月 4 日。

    311 引用 • 546 回帖
  • JRebel

    JRebel 是一款 Java 虚拟机插件,它使得 Java 程序员能在不进行重部署的情况下,即时看到代码的改变对一个应用程序带来的影响。

    26 引用 • 78 回帖 • 664 关注
  • Caddy

    Caddy 是一款默认自动启用 HTTPS 的 HTTP/2 Web 服务器。

    12 引用 • 54 回帖 • 165 关注
  • Dubbo

    Dubbo 是一个分布式服务框架,致力于提供高性能和透明化的 RPC 远程服务调用方案,是 [阿里巴巴] SOA 服务化治理方案的核心框架,每天为 2,000+ 个服务提供 3,000,000,000+ 次访问量支持,并被广泛应用于阿里巴巴集团的各成员站点。

    60 引用 • 82 回帖 • 595 关注