Skip to content

Attention-based Deep Reinforcement Learning-based Autonomous Robot Exploration Planner in ROS

License

Notifications You must be signed in to change notification settings

marmotlab/ARiADNE-ROS-Planner

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 

Repository files navigation

ARiADNE-ROS-Planner

ARiADNE is A Reinforcement learning apporach using Attention-based Deep Network. It is designed to tackle Lidar-based autonomous single-robot exploration in 2D action space. ARiADNE builds an informative graph based on the partial exploration map as the input of the attention-based neural network. The neural network trained by deep reinforcement learning will select one of the neighboring nodes as the next waypoint iteratively. The robot will follow the planned waypoint to explore the environment. The planner is trained to estimate the long-term exploration efficiency of each potential waypoint and find a policy that can maximize the expectation of the predicted exploration efficiency. The informative graph can be rarefied to make it applicable in relatively larger-scale applications.

If you are interested in more details, please check our related publications in ICRA2023 and RAL.

This repo contains the source code for ARiADNE planner in ROS1.

5 Jan 2025: support random starting location.

Demo

Here is a demo video showing ARiADNE planner exploring the indoor environment provided by TARE. The video is playing at the original speed. This experiment was conducted on an ASUS mini PC with an Intel i7-12700H CPU.

demo_indoor.mp4

In this demo, the robot traveled 948m in 545s when the exploration was completed. The average planning time was 0.17s. The average waypoint publishing frequency was around 2.5Hz. You can find the per-step record here. The final exploration trajectory is shown below.

The largest environment we tested is the tunnel environment as below:

tunnel.mp4

Usage

1. Prerequisites

We tested this planner on Ubuntu 18.04 ROS Melodic and Ubuntu 20.04 ROS Noetic. In particular, our planner relies on Octomap to transfer pointcloud to occupancy grid map:

sudo apt-get install ros-noetic-octomap

We recommend to use conda for package management. Our planner is coded in Python and based on Pytorch. Other than Pytorch, please install following packages by:

pip install scikit-image matplotlib

We tested our planner in various version of these packages so you can just install the latest one. Then you can download this repo and compile it.

git clone https://github.com/marmotlab/ARiADNE-ROS-Planner.git
cd ARiADNE-ROS-Planner
catkin_make

Note: We only use CPU to do the network inference, so you do not need a GPU.

2. Development environments

In practice, our planner needs to cooperate with a Lidar SLAM module which outputs sensor odometry and Lidar scan, and a waypoint follower module which navigates the robot to the planned waypoint. Fortunately, you can test our planner easily in the development environments provided by CMU Robotics Institute.

Please follow instructions for CMU Development Environment to set up the Gazebo simulation, SLAM module, and waypoint follower module.

3. Run the code

To run the development environment, go to the development environment folder in a terminal and run:

source devel/setup.bash 
roslaunch vehicle_simulator system_indoor.launch

Our planner can work in three of their environments: indoor, forest, and tunnel.

To run ARiADNE planner, go to the planner folder in another terminal (launch your conda environment if any) and run:

source devel/setup.bash 
roslaunch rl_planner rl_planner.launch

if running the planner in the forest environment, run:

roslaunch rl_planner rl_planner_forest.launch

if running the planner in the tunnel environment, run:

roslaunch rl_planner rl_planner_tunnel.launch

4. Test in other environments

As long as the starting coordination of the robot is $(0, 0)$, you should be able to run this code directly. However, to get better performance in different environments, you most likely need to tune some parameters in the launch file, such as the node resolution, the frontier downsample factor, and maybe the replanning frequency. Some brief introduction of these parameters can be found in parameter.py. Here are examples of applying ARiADNE planner in CMU forest and tunnel and two indoor scenarios provided by FAEL.

5. Train your own networks

You can train your own networks using ARiADNE or its ground truth critic variant. To run the trained model, replace the checkpoint file under the model folder.

Citation

If you find our work helpful or enlightening, feel free to cite our paper:

@inproceedings{cao2023ariadne,
  title={Ariadne: A reinforcement learning approach using attention-based deep networks for exploration},
  author={Cao, Yuhong and Hou, Tianxiang and Wang, Yizhuo and Yi, Xian and Sartoretti, Guillaume},
  booktitle={2023 IEEE International Conference on Robotics and Automation (ICRA)},
  pages={10219--10225},
  year={2023},
  organization={IEEE}
}
@article{cao2024deep,
  title={Deep Reinforcement Learning-based Large-scale Robot Exploration},
  author={Cao, Yuhong and Zhao, Rui and Wang, Yizhuo and Xiang, Bairan and Sartoretti, Guillaume},
  journal={IEEE Robotics and Automation Letters},
  year={2024},
  publisher={IEEE}
}

Author

Yuhong Cao

Note: I am seeking to implement this planner in C++. Feel free to contact me if you are interested in collaboration.

Credit

Development environment is from CMU.

Octomap is from University of Freiburg.

Quad tree is from Daniel Lindsley.

ChatGPT also contributes some code here and there.

About

Attention-based Deep Reinforcement Learning-based Autonomous Robot Exploration Planner in ROS

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published