Skip to content

Latest commit

 

History

History
executable file
·
524 lines (400 loc) · 27 KB

README.md

File metadata and controls

executable file
·
524 lines (400 loc) · 27 KB

Arena-Rosnav

A flexible, high-performance 2D simulator with configurable agents, multiple sensors, and benchmark scenarios for testing robotic navigation.

Arena-Rosnav uses Flatland as the core simulator and is a modular high-level library for end-to-end experiments in embodied AI -- defining embodied AI tasks (e.g. navigation, obstacle avoidance, behavior cloning), training agents (via imitation or reinforcement learning, or no learning at all using conventional approaches like DWA, TEB or MPC), and benchmarking their performance on the defined tasks using standard metrics.

Training Stage Deployment Stage

What is this repository for?

Train DRL agents on ROS compatible simulations for autonomous navigation in highly dynamic environments. Flatland-DRL integration is inspired by Ronja Gueldenring's work: drl_local_planner_ros_stable_baselines. Test state of the art local and global planners in ROS environments both in simulation and on real hardware. Following features are included:

  • Setup to train a local planner with reinforcement learning approaches from stable baselines3

  • Training in simulator Flatland in train mode

  • Local planner has been trained on static and dynamic obstacles with highly dynamic tasks

  • Implementation of intermediate planner classes to combine local DRL planner with global map-based planning of ROS Navigation stack

  • Integration of other obstacle avoidance approaches in ROS

  • Testing a variety of planners (learning based and model based) within specific scenarios in test mode

  • Modular structure for extension of new functionalities and approaches

Recent Updates

  • 04.02.2021: Added Multiprocessing for training speedup
  • 26.01.2021: Added Scenario Tasks: generate your own scenario by specifying a scenario.json

Documentation & References

1. Installation

Please refer to Installation.md for detailed explanations about the installation process.
If you want to use Docker, please refer to our Dockerfile

2. Usage

DRL Training

Please refer to DRL-Training.md for detailed explanations about agent, policy and training setups.

2.1 Test the simulation environment and task generator

  • In one terminal, start simulation. You can specify the following parameters:

    • train_mode:=<true, false>
    • use_viz:=<true, false> (default true)
    • local_planner:=<teb,dwa,mpc,cadrl,arena2d> (default dwa)
    • task_mode:=<random, manual, scenario> (default random)
    • obs_vel:= # maximum velocity of dynamic obstacles [m/s]. It is recommended to set a max velocity within [0.1,0.7] (default 0.3)
    • map
roslaunch arena_bringup start_arena_flatland.launch train_mode:=false use_viz:=true local_planner:=dwa map_file:=map1 obs_vel:=0.3

Now you can click on the generate task button in rviz to generator a new random task (random obstacles and goal is published to /goal). It will automatically navigate to that goal, once you start one of our local planners, which are triggered by a new /goal. If you starte with task_mode "manual" you can specify your goal using the specify Flatland Navigation goal (using normal 2D navigation goal will trigger the move_base planner, thus only works with teb and dwa)

Run Arena2D models in Rosnav

  • start simulation as above, then navigate to the folder arena-rosnav/arena_navigation/arena_local_planner/learning_based/arena_ros/scripts/ and execute arena_node_tb3.py
python arena_node_tb3.py

2.2. [Quick start] start simulation env & plan manager

roslaunch arena_bringup start_arena_flatland.launch  train_mode:=false

start_flatland.launch will start several other sublaunch files and some neccesary ros packages:

  1. start simulator node: start flatland, load robot model
  2. start map server node: load map, which will provide occupancy grid used for mapping functions later
  3. start fake localization: which will provide static tf map_to_odom, in order to have localization of the robot.
  4. start task generator node: which provide task generation service for rviz_plugin(Generate Task)
  5. start plan manager node: provide manager for robot state estimation, mapping, global planner and local planner, which is the key for navigation framework. The move_base is contained, because currently we need its global_planner and mapping functions, later they won't be needed.
  6. /train_mode/:
  • if true, the simulator(flatland) will provide a step_world service and the simulator will update its simulation when he receives a step_world service request.
  • if true, the plan manager will generate subgoal topic always as goal(global goal) topic.
  • if false, you can also use move_base action triggered by rviz_plugin button 2D Navigation Goal.

2.3. [Quick start] test DRL training

Export turtlebot model for simulation

  • In one terminnal, export turtlebot model and start simulation
roslaunch arena_bringup start_arena_flatland.launch  train_mode:=true 	use_viz:=true  task_mode:=random
  • In another terminal
workon rosnav
roscd arena_local_planner_drl
python scripts/training/train_example.py

first activate your python3 env, which contains libaraies stable_baseline3, geometry2 then python run the script.

Hint: During 2021-01-05 and 2021-01-10, arena_local_planner_drl package is still under the development, which means the api of the class could be drastically changed. Sorry about the inconvinience!

2.4. Rviz plugins:

  1. 2D Nav Goal: triggers move_base action
  2. Spawn Model: load a new model.yaml to flatland simulator
  3. Arena Nav Goal: set (global) goal for arena navigation
  4. Generate Task: change task, which changes the position of obstacles and set a new goal for arena navigation

3.Design

3.1. Structure of the packges

  1. ./forks/flatland:(simulator)
  2. arena_bringup:
    1. config
    2. launch
      1. sublaunch:
        1. flatland_simulator.launch
        2. fake_localization.launch
        3. plan_manager.launch
        4. move_base.launch
        5. task_generator.launch
      2. start_arena_flatland.launch
    3. rviz
  3. arena_navigation:
    1. fake_localization
    2. mapping
    3. global_planner
    4. local_planner
      1. learning_based 1.drl 2.immitation_learning 3.trained-models
      2. model_based
    5. plan_manager
    6. plan_msgs
  4. simulator_setup: (saves flatland model files)
    1. maps
    2. obstacles
    3. robot
    4. scripts (e.g. behavior modeling, etc.)
  5. task_generator:
  6. utils
    1. rviz_plugin
    2. plan_visualization

3.2. Navigation framework

arena_navigation

  1. fake_localization(pkg)
  2. mapping:
    1. costmap2D(pkg)
    2. Euclean Signed Distancefield Map(pkg)
    3. Topology Graph(pkg)
    4. Voxgraph(pkg)
    5. ...
  3. global_planner
    1. arena_global_planner_Dijkstra(pkg)
    2. arena_global_planner_Astar(pkg)
    3. arena_global_planner_JPS(Jump point search)(pkg)
    4. arena_global_planner_KinoAstar(pkg)
    5. arena_global_planner_Informed_RRTstar(pkg)
    6. ...
  4. local_planner
    1. learning_based
      1. arena_local_planner_drl(pkg)
      2. arena_local_planner_cardl(pkg)
      3. ...
    2. model_based
      1. arena_local_planner_TEB(pkg)
      2. arena_local_planner_VFH*(pkg)
      3. ...
  5. plan_manager(pkg)
    1. plan_collector
    2. plan_manager
    3. plan_manager_node
  6. plan_msgs(pkg)
    1. msg
      1. RobotState.msg
    2. srv
      1. Subgoal.srv

Plan manager

  • plan_manager_node will init a ros node for plan_manager
  • plan_manager is implemented as a Finite State Machine
  • plan_manager is responsible for state transfer, ros communication and call plan functions from plan_collecor

Plan collector

  • plan_collector has no ros communication tasks, plan_collecor only responsible for algorithms
  • plan_collector calls libraries from other pkgs(e.g. pkgs in mapping, local planner, global planner) to achieve its functions
  • plan_collector also responsible for subgoal generation, which is the job of intermediate planner.

Plan msgs

  • saves user-defined msg or srv for arena navigation

3.3. Simulator: Flatland

Flatland is a 2D physical simulator based on box2D, which is made to be integratable with ROS and easy to extend functions with its plugin mechanism.

In our project, we have modified and extended the original Flatland source repositary in order to make it better suitable to our DRL planning purpose. The parts that have been modified will be cleared somehow in following sections.

A great introduction to flatland is listed in following website, please checi it out (most importantly in order to know how to create plugin in flatland):

Things need to know:

  • How flatland updates its simulation progress
  • How to write model .yaml files for flatland
  • How to create flatland plugins(e.g. laser, driver, motion behavior) which can be added to the model .yaml file
How flatland updates its simulation progress
flatland_server/src/flatland_server_node.cpp
flatland_server/src/simulation_manager.cpp         (modified by our project)
flatland_server/src/world.cpp
flatland_server/src/timekeeper.cpp
flatland_plugins/src/laser.cpp                     (modified by our project)

check out these files, everything relative to simulation update is contained there. We made some modification in simulation_manager.cpp, where we create a /step_world service server.

How to write model .yaml files for flatland

Robot, Obstacles and world can be described by .yaml files, which provide easy setting to users.

check out the model section in http://flatland-simulator.readthedocs.io

How to create flatland plugins

Sensors such as laser, actuator such ad diff_driver & other user defined motion behaviors can be coded as a flatland plugin and added to the model .yaml file.

check out the plugin section in http://flatland-simulator.readthedocs.io

flatland_plugins/src/laser.cpp                     (modified by our project)
flatland_plugins/src/diff_drive.cpp                (modified by our project)
flatland_plugins/src/model_tf_publisher.cpp        (modified by our project)
flatland_plugins/include/flatland_plugins/tween.h  (for dynamic obstacle motion behavior)
flatland_plugins/include/flatland_plugins/update_timer.h

These are the plugins that currently we are using and some of them are modified.

Modification are mostly done in these two functions in each plugins. These change are made intended to make the publication of topics done in AfterPhysicsStep otherthan in BeforePhysicsStep.

void BeforePhysicsStep(const Timekeeper& timekeeper);
void AfterPhysicsStep(const Timekeeper &timekeeper) ;

3.4. Task Generator

To be added...

3.5. Utils

contains rviz_plugins & planning visulizations needed to be showed in rviz.

4. DRL Local planner(Training and Testing)

Communication:

DRL local planner get the needed observation info by using ROS communication. This may slows down the training, but for current version we just keep it.

DRL local planner get observation info from:

  • flatland server: laser scan
  • plan manager: robot state, subgoal

DRL local planner send action command to flatland server

  • flatland server: diff_drive
Observation synchronization

DRL local planner contains observation collector and we designed a synchronization mechanism for following important reasons & aspects:

  1. In real world, each sensor has its own publishing rate and are different from each other
  2. The action calculation should based on the observations that are synchronized, otherwise is useless.
  3. The calculated action is only valid for a specified time horizon(control horizon),e.g. 0.2s. For different control horizon, the action space should be different.
    1. example 1: action is calculated every 0.01s, time horizon=0.01s, suppose calculated action=1m/s, in this time horizon the robot will actually move 0.01m.
    2. example 2: action is calculated every 0.5s, time horizon=0.5s, suppose calculated action=1m/s, in this time horizon the robot will actually move 0.5m.
    • From 1 & 2, one can see for a same action space, a different time horizon will result in different actual result.

To be added...

4.1 DRL Agent Training

As a fundament for our Deep Reinforcement Learning approaches StableBaselines3 was used.

Features included so far
  • Simple handling of the training script through program parameters
  • Choose a predefined Deep Neural Network
  • Create your own custom Multilayer Perceptron via program parameters
  • Networks will get trained, evaluated and saved
  • Load your trained agent to continue training
  • Optionally log training and evaluation data
  • Enable and modify training curriculum
Quick Start
  • In one terminnal, start simulation
roslaunch arena_bringup start_arena_flatland.launch train_mode:=true use_viz:=true task_mode:=random
  • In another terminal
workon rosnav
roscd arena_local_planner_drl
python scripts/training/train_agent.py --agent MLP_ARENA2D

4.1.1 Program Arguments

Generic program call:

train_agent.py [agent flag] [agent_name | unique_agent_name | custom mlp params] [optional flag] [optional flag] ...
Program call Agent Flag (mutually exclusive) Usage Description
train_agent.py --agent agent_name (see below) initializes a predefined network from scratch
--load unique_agent_name (see below) loads agent to the given name
--custom-mlp custom mlp params (see below) initializes custom MLP according to given arguments

Custom Multilayer Perceptron parameters will only be considered when --custom-mlp was set!

Custom Mlp Flags Syntax Description
--body {num}-{num}-... architecture of the shared latent network
--pi {num}-{num}-... architecture of the latent policy network
--vf {num}-{num}-... architecture of the latent value network
--act_fn {relu, sigmoid or tanh} activation function to be applied after each hidden layer
Optional Flags Description
--n {num} timesteps in total to be generated for training
--tb enables tensorboard logging
-log, --eval_log enables logging of evaluation episodes
--no-gpu disables training with GPU

Examples

Training with a predefined DNN

Currently you can choose between 3 different Deep Neural Networks each of which have been object of research projects:

Agent name Inspired by
MLP_ARENA2D arena2D
DRL_LOCAL_PLANNER drl_local_planner
CNN_NAVREP NavRep

e.g. training with the MLP architecture from arena2D:

train_agent.py --agent MLP_ARENA2D
Load a DNN for training

In order to differentiate between agents with similar architectures but from different runs a unique agent name will be generated when using either --agent or --custom-mlp mode (when train from scratch).

The name consists of:

[architecture]_[year]_[month]_[day]__[hour]_[minute]

To load a specific agent you simply use the flag --load, e.g.:

train_agent.py --load MLP_ARENA2D_2021_01_19__03_20

Note: currently only agents which were trained with PPO given by StableBaselines3 are compatible with the training script.

Training with a custom MLP

Instantiating a MLP architecture with an arbitrary number of layers and neurons for training was made as simple as possible by providing the option of using the --custom-mlp flag. By typing in the flag additional flags for the architecture of latent layers get accessible (see above).

e.g. given following architecture:

					   obs
					    |
					  <256>
					    |
					  ReLU
					    |
					  <128>
					    |
					  ReLU
				    /               \
				 <256>             <16>
				   |                 |
				 action            value

program must be invoked as follows:

train_agent.py --custom-mlp --body 256-128 --pi 256 --vf 16 --act_fn relu

4.1.2 Hyperparameters

You can modify the hyperparameters in the upper section of the training script which is located at:

/catkin_ws/src/arena-rosnav/arena_navigation/arena_local_planner/learning_based/arena_local_planner_drl/scripts/training/train_agent.py

Following hyperparameters can be adapted:

Parameter Description
robot Robot name to load robot specific .yaml file containing its settings.
gamma Discount factor
n_steps The number of steps to run for each environment per update
ent_coef Entropy coefficient for the loss calculation
learning_rate The learning rate, it can be a function of the current progress remaining (from 1 to 0) (i.e. batch size is n_steps * n_env where n_env is number of environment copies running in parallel)
vf_coef Value function coefficient for the loss calculation
max_grad_norm The maximum value for the gradient clipping
gae_lambda Factor for trade-off of bias vs variance for Generalized Advantage Estimator
batch_size Minibatch size
n_epochs Number of epoch when optimizing the surrogate loss
clip_range Clipping parameter, it can be a function of the current progress remaining (from 1 to 0).
reward_fnc Number of the reward function (defined in ../rl_agent/utils/reward.py)
discrete_action_space If robot uses discrete action space
task_mode Mode tasks will be generated in (custom, random, staged). In custom mode one can place obstacles manually via Rviz. In random mode there's a fixed number of obstacles which are spawned randomly distributed on the map after each episode. In staged mode the training curriculum will be used to spawn obstacles. (more info)
curr_stage When "staged" training is activated which stage to start the training with.

(more information on PPO implementation of SB3)

Note: For now further parameters like max_steps_per_episode or goal_radius have to be changed inline (where FlatlandEnv gets instantiated). n_eval_episodes which will take place after eval_freq timesteps can be changed also (where EvalCallback gets instantiated).

4.1.3 Reward Functions

The reward functions are defined in

../arena_local_planner_drl/rl_agent/utils/reward.py

At present one can chose between two reward functions which can be set at the hyperparameter section of the training script:

rule_00 rule_01
Reward Function at timestep t
reward description value
success reward
collision reward
danger reward
progress reward
move reward
Reward Function at timestep t
reward description value
success reward
collision reward
danger reward
progress reward (*)
move reward

*higher weight applied if robot drives away from goal (to avoid driving unneccessary circles)

4.1.4 Training Curriculum

For the purpose of speeding up the training an exemplary training currucilum was implemented. But what exactly is a training curriculum you may ask. We basically divide the training process in difficulty levels, here the so called stages, in which the agent will meet an arbitrary number of obstacles depending on its learning progress. Different metrics can be taken into consideration to measure an agents performance.

In our implementation a reward threshold or a certain percentage of successful episodes must be reached to trigger the next stage. The statistics of each evaluation run is calculated and considered. Moreover when a new best mean reward was reached the model will be saved automatically.

Exemplary training curriculum:

Stage Static Obstacles Dynamic Obstacles
1 0 0
2 10 0
3 20 0
4 0 10
5 10 10
6 13 13

4.1.5 Important Directories

Path Description
../arena_local_planner_drl/agents models and associated hyperparameters.json will be saved to and loaded from here (uniquely named directory)
../arena_local_planner_drl/configs yaml files containing robots action spaces and the training curriculum
../arena_local_planner_drl/training_logs tensorboard logs and evaluation logs
../arena_local_planner_drl/scripts python file containing the predefined DNN architectures and the training script