rrt_exploration

一个实现基于多机器人RRT的地图探测算法的ROS包。 它还具有使用图像处理来提取边界点的基于图像的边沿检测

1.介绍

“rrt_exploration”是实现移动机器人的多机器人地图探索算法的ROS包。 它是基于快速探索随机树(RRT)算法。 它使用占用网格作为地图表示。该包具有5个不同的ROS节点:

1 全局RRT边界点检测器节点。

2 局部RRT边界点检测器节点。
3 基于OpenCV的边界检测器节点。
4 滤波器节点。
5 分配器节点。

 

  • Global RRT frontier point detector node.
  • Local RRT frontier point detector node.
  • OpenCV-based frontier detector node.
  • Filter node.
  • Assigner node.

 

这是一个播放列表,显示在真实机器人上运行的软件包和Gazebo模拟:

2.软件包要求

该套件已经在ROS Kinetic和ROS Indigo上进行了测试,它应该可以在其他发行版上工作,如jade。 在安装软件包之前需要以下要求:
1-你应该安装一个ROS发行版(indigo or later. Recommended is either indigo or kinetic)。
2-创建工作空间。
3-安装了“gmapping”ROS包,可以在终端中键入以下命令:

$ sudo apt-get install ros-kinetic-gmapping

  4-安装ROS导航堆栈。 您可以使用以下命令来执行此操作:

$ sudo apt-get install ros-kinetic-navigation

5 - 你应该有Python 2.7。 (它没有在Python 3测试)。

Ubuntu16.04+python-2.7的安装

在Ubuntu中自带的有python模块,但是该模块较为简单,并不含有日常处理所需的数据库和安装包。接下来说一下python的手动安装方法,并附带安装我所需要的库。 注意:ubuntu16.04中包含了python-2.7,python-3.5,在terminal下直接键入python可查看你所使用的版本,如图为我自己的python版本:

如果你所使用的也是2.7的话可以安装如下步骤进行安装,若为3.5时所需安装有所不同。

1.安装所需依赖

$ sudo apt-get install libfreetype6-dev

 2.下载安装包并解压。

$ wget http://effbot.org/downloads/Imaging-1.1.7.tar.gz
$ tar -zxvf Imaging-1.1.7.tar.gz

 3.修改setup.py 中依赖库的路径

$ cd Imaging-1.1.7
$ emacs setup.py (emacs与vim一样只是文本编辑器 sudo apt-get install emacs)

配置zlib ,freetype路径

如果不知道系统中库所在位置,可以使用如下命令查看:

$ pkg-config –variable=libdir zlib
$ pkg-config –variable=libdir freetype2

TCL_ROOT = None
JPEG_ROOT = None
ZLIB_ROOT = “/usr/lib/x86_64-linux-gnu”
TIFF_ROOT = None
FREETYPE_ROOT = “/usr/lib/x86_64-linux-gnu”
LCMS_ROOT = None

 4.安装

$ sudo python setup.py build

确保设定过路径的库都是 avilable的,然后进行安装:

$ sudo python setup.py install

经实测,以上安装方法在virtualenv中也是可行的。

以下是我所需的数据库,如果有需要其他的可以查阅其他资料

$ sudo apt-get install python-scipy
$ sudo apt-get install python-mysqldb

以上是python的安装过程。

 

 

6 - 您应该有/安装以下python模块:

-OpenCV (cv2)

$ sudo apt-get install python-opencv

 -Numpy

$ sudo apt-get install python-numpy

-Sklearn

$ sudo apt-get install python-scikits-learn

3.硬件要求

可与导航堆栈一起使用的移动机器人(发布/ odom和/ tf.接收速度命令..)。 机器人还必须配备激光扫描仪或任何发布激光扫描信息的传感器(sensor_msgs / LaserScan)。

4.安装

下载包并将其放在工作区的/ src文件夹中。 然后使用catkin_make编译。

 

5.设置你的机器人

该软件包为单个或多个机器人提供了一个探索策略。 但是,为了使其正常工作,您应该使用导航堆栈设置机器人。 并且每个机器人应该从gmapping包运行“slam_gmapping”节点。

此外,机器人必须按照以下方式进行设置和准备。

注意:如果要快速运行和测试该软件包,您可以尝试使用rrt_exploration_tutorials软件包,为单个和多个机器人提供Gazebo模拟,您可以直接使用该软件包。

5.1 机器人网络 

对于多机器人配置,该软件包不需要特殊的网络配置,它可以通过使用单个ROS主机(可以是其中一个机器人)来工作。 所以在其他机器人上,ROS_MASTER_URI参数应该指向主机地址。 有关在多台机器上设置ROS的更多信息,请点击this

5.2 机器人的框架名称在tf

所有机器人的框架应以其名称为前缀。 机器人的命名从“/ robot_1”,“/ robot_2”,“/ robot_3”,...等开始。 即使您使用单一机器人的包装,机器人的框架也应以其名称(即/ robot_1)为前缀。 所以对于robot_1,tf树中的框架应该如下所示:

tf是一个包,让用户随着时间的推移跟踪多个坐标系。 tf保持时间缓冲的树结构中的坐标系之间的关系,并且允许用户在任何所需时间点的任何两个坐标系之间转换点,向量等。)

5.3 机器人的节点和主题名称

 机器人上运行的所有节点和主题也必须以其名称为前缀。 对于机器人1,节点名称应如下所示:/ robot_1 / move_base_node,/ robot_1 / slam_gmapping。

主题名称应该是:/ robot_1 / odom,/ robot_1 / map / / robot_1 / base_scan,..etc。

5.4 在机器人上设置导航堆栈

 在机器人上引导导航堆栈的move_base_node节点必须正在运行。 该包(rrt_exploration)生成目标勘探目标,每个机器人必须能够接收这些点并向其移动。 这就是为什么需要导航堆栈。 此外,每个机器人必须具有全局和局部成本图。 所有这些都来自move_base_node。

5.5 构建地图节点

每个机器人应该具有从gmapping包生成的局部地图。

5.6 地图合并节点

对于多机器人的情况,应该有一个将所有局部地图合并为一个全局地图的节点。 你可以使用这个包。

6.节点

有3种类型的节点; 用于检测占用网格图中的边界的节点,用于过滤检测到的点的节点以及用于将点分配给机器人的节点。 下图显示了结构:

6.1 global_rrt_frontier_detector

global_rrt_frontier_detector节点占用网格,并在其中找到边界点(它们是勘探目标)。 它发布检测到的点,以便过滤器节点可以处理。 在多机器人配置中,其目的是仅运行该节点的单个实例。
如果需要,运行全局边沿检测器的附加实例可以提高边界点检测的速度。
 

6.1.1 订阅主题

map (nav_msgs/OccupancyGrid)

主题名称由〜map_topic参数定义。 它是节点将在其上接收地图的主题名称。

clicked_point (geometry_msgs/PointStamped)

global_rrt_frontier_detector节点需要定义要探索的区域。 该主题是节点收到定义该区域的五个点。 前四个点是四个定义要探索的正方形区域,最后一个点是树的起点。 在发表了关于这个话题的五点后,RRT将开始检测边界。 这五点意图由Rviz使用(https://github.com/hasauino/storage/blob/master/pictures/publishPointRviz_button.png?raw=true)按钮发布。

6.1.2发表主题

 detected_points (geometry_msgs/PointStamped)

节点发布检测到边界点的主题。

~shapes (visualization_msgs/Marker)

在此主题中,节点发布线形状,以使用Rviz可视化RRT。

 

6.1.3参数

~map_topic (string, default: "/robot_1/map")

此参数定义节点将在其上接收地图的主题名称。

~eta (float, default: 0.5) 

该参数控制用于检测边界点的RRT的增长率,单位为米。 该参数应根据地图大小进行设置,非常大的值会导致树长得更快,从而更快地检测边界点,但是增长速度很大,也意味着树将在地图中缺少小角。

6.2 local_rrt_frontier_detector

 该节点类似于global_rrt_frontier_detector。 但是,它的作用不同,因为这里的树每次检测到边界点时都会保持重置。 该节点旨在沿着global_rrt_frontier_detector节点运行,它负责快速检测位于机器人附近的边界点。
在多机器人配置中,每个机器人运行local_rrt_frontier_detector的一个实例。 因此,对于3台机器人的团队,将有4个节点用于检测边界点:3个局部检测器和1个全局检测器。 如果需要,运行局部边界检测器的附加实例可以提高边界点检测的速度。
所有检测器将在同一主题(“/ detected_points”)上发布检测到的边界点。

6.2.1 订阅主题

 map (nav_msgs/OccupancyGrid)

主题名称由〜map_topic参数定义。 它是节点将在其上接收地图的主题名称。

clicked_point (geometry_msgs/PointStamped)

lobal_rrt_frontier_detector也预订了与global_rrt_frontier_detector类似的主题。

 6.2.2 发表主题

detected_points (geometry_msgs/PointStamped)

节点发布检测到边界点的主题。

~shapes (visualization_msgs/Marker)

在此主题中,节点发布线形状,以使用Rviz可视化RRT。

6.2.3 参数

~/robot_1/base_link (string, default: "/robot_1/base_link")

机架附着的框架。 每当树复位时,它将从从此框架获取的当前机器人位置开始。

~map_topic (string, default: 0.5)

此参数定义节点将在其上接收地图的主题名称。

~eta (float)

该参数控制用于检测边界点的RRT的增长率,单位为米。 该参数应根据地图大小进行设置,非常大的值会导致树长得更快,从而更快地检测边界点,但是增长速度很大,也意味着树将在地图中缺少小角。

6.3 frontier_opencv_detector

该节点是另一个边界检测器,但不是基于RRT。 该节点使用OpenCV工具来检测边界点它旨在单独运行,并且在多机器人配置中,只应运行一个实例(运行此节点的附加实例没有任何区别)。
最初这个节点被实现与基于RRT的边界检测器进行比较。 沿着RRT检测器(局部和全局)一侧运行该节点可以提高检测点的速度。
注意:您可以运行任何类型和任何数量的检测器,所有检测器将发布在过滤器节点(将在下一节中介绍)正在订阅的相同主题上。 另一方面,过滤器将过滤的入口点传递给分配器,以便命令机器人探索这些点。

6.3.1 订阅主题

map (nav_msgs/OccupancyGrid)

主题名称由〜map_topic参数定义。 它是节点将在其上接收地图的主题名称。

6.3.2 发表主题 

detected_points (geometry_msgs/PointStamped)

节点发布检测到边界点的主题。

shapes (visualization_msgs/Marker)

在此主题中,节点使用Rviz发布要进行可视化的检测点。

6.3.3 参数

~map_topic (string, default: "/robot_1/map")

此参数定义节点将在其上接收地图的主题名称。

6.4滤波器

滤波器节点从所有检测器接收检测到的边界点,对点进行滤波,并将它们传递给分配器节点以命令机器人。 过滤包括旧点和无效点的选择,也是冗余点。

6.4.1 订阅主题

map (nav_msgs/OccupancyGrid)

主题名称由〜map_topic参数定义。 它是节点将在其上接收地图的主题名称。

robot_x/move_base_node/global_costmap/costmap (nav_msgs/OccupancyGrid)

其中x(在robot_x中)是指机器人的编号。
过滤器节点预订所有机器人的所有costmap主题,因此需要costmap。 通常,导航堆栈应发布costmap(在引导机器人上的导航堆栈之后,每个机器人将具有一个costmap)。 例如,如果n_robots = 2,则节点将订阅:robot_1 / move_base_node / global_costmap / costmap和robot_2 / move_base_node / global_costmap / costmap。 costmaps用于删除无效点。
注意:机器人对应的所有节点的命名空间应以robot_x开头。 再次,x是机器人编号。

The goals topic (geometry_msgs/PointStamped)

主题名称由〜goals_topic参数定义。 这是滤波器节点接收检测到的边界点的主题。

6.4.2 发表主题

frontiers (visualization_msgs/Marker)

过滤器节点发布用于Rviz可视化的接收边界点的主题。

centroids (visualization_msgs/Marker)

过滤器节点仅发布用于Rviz可视化的过滤边界点的主题。

filtered_points (invalid message type for MsgLink(msg/type))

所有过滤的点作为一个点数组发送到该主题上的分配器节点。

6.4.3 参数

 ~map_topic (string, default: "/robot_1/map")

此参数定义节点将在其上接收地图的主题名称。 该地图用于知道哪些点不再是边界点(旧点)。

~costmap_clearing_threshold (float, default: 70.0)

占用率大于此阈值的边界点将被视为无效。 占用值是从成本图中获得的。

~info_radius (float, default: 1.0)

用于计算边界信息增益的信息半径。

~goals_topic (string, default: "/detected_points")

定义节点接收检测到的边界点的主题。

~n_robots (float, default: 1.0)

机器人数量

~rate (float, default: 100.0)

节点循环速率(Hz)。

6.5 分配器

该节点接收到目标探测目标,即目标探测目标,这是过滤器节点发布过滤的边界点,并相应地命令机器人。 分配器节点通过move_base_node命令机器人。 这就是为什么你在机器人上引导导航堆栈。

6.5.1 订阅主题

map (nav_msgs/OccupancyGrid)

 主题名称由〜map_topic参数定义。

Filtered frontier points topic (nav_msgs/OccupancyGrid)

 主题名称由〜frontiers_topic参数定义。

The goals topic (invalid message type for MsgLink(msg/type))

主题名称由〜goals_topic参数定义。 这是滤波器节点接收检测到的边界点的主题。

6.5.2 参数

~map_topic (string, default: "/robot_1/map")

此参数定义节点将接收地图的主题名称。 在单机器人情况下,应将此主题设置为机器人的地图主题。 在多机器人案例中,此主题必须设置为全局合并映射。

~info_radius (float, default: 1.0)

用于计算边界信息增益的信息半径。

~info_multiplier (float, default: 3.0)

单位是米。 该参数用于重视成本上的边界点的信息增益(到边界点的预期行驶距离)。

~hysteresis_radius (float, default: 3.0)

单位是米。 该参数定义了滞后半径。

~hysteresis_gain (float, default: 2.0)

单位是米。 该参数定义了滞后增益。

~frontiers_topic (string, default: "/filtered_points")

分配器节点接收过滤边界点的主题。

~n_robots (float, default: 1.0)

机器人数量

~delay_after_assignement (float, default: 0.5)

单位是秒。 它定义每个机器人分配后的延迟量。

~rate (float, default: 100.0)

节点循环速率(Hz)。

7.教程

这里列出了有关如何使用包的教程。

Installation

本节将展示除了包本身(rrt_exploration)和rrt_exploration_tutorials软件包之外,还可以安装所需的软件包和python模块。 本教程假设您已经安装了ROS,并且有一个工作区。

1. Install all required packages

In a terminal, write the following commands:

$ sudo apt-get install ros-kinetic-gmapping ros-kinetic-navigation ros-kinetic-kobuki ros-kinetic-kobuki-core ros-kinetic-kobuki-gazebo

$ sudo apt-get install python-opencv python-numpy python-scikits-learn

2. Install rrt_exploration and rrt_exploration_tutorials

假设您的工作区文件夹位于主目录中,并命名为catkin_ws(如果不是,请相应地更改命令):

$ cd ~/catkin_ws/src/
$ git clone https://github.com/hasauino/rrt_exploration.git
$ git clone https://github.com/hasauino/rrt_exploration_tutorials.git
$ cd ~/catkin_ws
$ catkin_make

 就是这个! 现在你可以测试包。

3.Tutorials list(教程列表)

在教程中,我们将使用Gazebo模拟器。 您下载了rrt_exploration_tutorials软件包后,您已经拥有所有需要的文件。

 

 

1-Single robot with laser scanner.

1.Gazebo simulation

在rrt_exploration_tutorials软件包附带的启动文件中,您会发现几个启动文件。 在本教程中,我们将使用针对单机器人仿真的。

1-In a terminal, run the following command:

$ roslaunch rrt_exploration_tutorials single_simulated_house.launch

 这将打开Gazebo和RViz。 机器人设置为使用rrt_exploration软件包。 主要是机器人框架以“robot_1”为前缀,对于节点和主题名称也是如此。 

运行以上指令出现以下问题:

解决方法:

这个问题一般有两个可能的原因,一个是忘了进行source,只需要回到上层进行source即可。

$ cd ~/catkin_ws

$ source devel/setup.bash

第二个错误是我最近刚发现的,因为我们默认的包是git clone在src下的,当你将新的包git clone在其他地方时,source命令就会出错。因此我将该包剪切至src下,并重新执行

$ source devel/setup.bash 后,命令执行成功。


2.Start Exploration

我们将在rrt_exploration包中使用一个名为“single.launch”的启动文件。 此启动文件启动全局和局部检测器,过滤器和分配器节点。

$ roslaunch rrt_exploration single.launch

 

3.Troubleshooting(故障排除)

 

这意味着gazebo目前正在为您下载仿真模型。 如果花了太长时间,您可以离线下载所有gazebo模型,然后手动放置在“models”文件夹(路径:〜/ .gazebo / models)中,如下所示:

$ wget -l 2 -nc -r "http://models.gazebosim.org/"
$ cd models.gazebosim.org
$ mkdir -p ~/.gazebo/models/
$ cp -r * ~/.gazebo/models/

 

 仿真结果:

 

 

 

posted @ 2017-09-15 14:47  丹妮儿的生活  阅读(3191)  评论(1编辑  收藏  举报