[Paper]
This project contains the code for setting up and running the benchmarking experiments of ARA* with motion primitives from SMPL and RRT-Connect with uniform sampling from OMPL.
The following instructions are intended for a native ROS workspace installation, from section 1.2 onwards. In addition, instructions for setting up a docker container (in which the same steps can be followed) using a Dockerfile are provided in (section 1.1) along with the additional final steps for exporting the experiments' results, in section 3. If you are not familiar with the ROS infrastructure, using the Docker installation is recommended.
-
You can install docker (if not already installed) on you machine by following the instructions here.
-
Then recursively clone this repository:
git clone --recurse-submodules https://github.com/gsotirchos/benchmarking_planners
-
Call the image building script:
benchmarking_planners/benchmarking_utils/docker/build-docker.sh
Now you can start an interactive docker session and follow the instructions from step 2 onwards. The name of the workspace is /ws
.
sudo docker run -it --name benchmarking_container benchmarking
The following instructions have been tested on Ubuntu 20.04. Similar instructions should work for other Linux distributions.
-
Install dependencies:
-
Required packages
sudo apt update sudo apt install \ build-essential pkg-config \ python3-catkin-tools rospack-tools \ cmake wget git zip python3-pip
-
GCC 7 (for building SMPL)
sudo apt install gcc-7 g++-7 export CC="$(which gcc-7)" export CXX="$(which g++-7)" unset CMAKE_GENERATOR # use makefiles
-
git clone -b epase https://github.com/shohinm/sbpl \ && cd sbpl mkdir build cd build cmake -Wno-dev .. \ && make \ && sudo make install cd ../..
-
pip install urdfpy numpy==1.20
-
-
Prepare a workspace and clone this repository:
mkdir -p benchmarking_ws/src cd benchmarking_ws/src git clone --recurse-submodule https://github.com/gsotirchos/benchmarking_planners
-
Install ROS dependencies:
cd .. rosdep install --from-paths ./src -i -r -y
-
Build the workspace:
catkin config \ --extend /opt/ros/"${ROS_DISTRO}" \ --cmake-args \ -DCMAKE_BUILD_TYPE=RelWithDebInfo \ -Wno-dev catkin build source devel/setup.bash
-
Extract Pyre's pre-generated datasets and database:
unzip "$(rospack find pyre)/datasets.zip" -d "$(rospack find pyre)" unzip "$(rospack find pyre)/database.zip" -d "$(rospack find pyre)"
-
Update the Fetch robot's URDF geometry using SBPL's collision spheres definition:
cp "$(rospack find robowflex_resources)/fetch/robots/fetch.urdf" \ "$(rospack find robowflex_resources)/fetch/robots/fetch.backup" "$(rospack find benchmarking_utils)/scripts/sbpl2urdf" \ "$(rospack find sbpl_collision_checking_test)/config/collision_model_fetch.yaml" \ "$(rospack find robowflex_resources)/fetch/robots/fetch.urdf"
-
Source the workspace's environment setup file:
source devel/setup.bash
-
Start a rosmaster instance:
roscore # in a separate terminal
-
Source the benchmarking script to generate the planning results:
source benchmarking_utils/bash_scripts/benchmark_smpl.sh
Note
Each run's results are stored in ~/.ros/smpl_benchmarks/<timestamp>/<problem-name>.csv
and then symlinked in ~/.ros/smpl_benchmarks/<problem-name>.csv
.
-
Run the following scripts to benchmark with the full databases (500):
rosrun pyre benchmark.sh
(Based on steps 1 and 2 from section 4) Benchmarking and Visualizing the results in Pyre's README)
Note
Each run's results are stored and overwritten in $(rospack find pyre)/benchmark/<problem-name>/<planner>_Experiment.log
.
Based on step 3 from section 4) Benchmarking and Visualizing the results in Pyre's README:
-
Use the
ompl_benchmark_statistics.py
script to aggregate the benchmarking results for each dataset.# Go to the benchmarking folder roscd pyre/benchmark # Call the ompl script to aggregate the results in an SQL database python3 ompl_benchmark_statistics.py shelf_zero_test/*.log -d shelf_zero_test_results.db python3 ompl_benchmark_statistics.py shelf_height_test/*.log -d shelf_height_test_results.db python3 ompl_benchmark_statistics.py shelf_height_rot_test/*.log -d shelf_height_rot_test_results.db
Important
If you ran the experiments inside a Docker container you can then copy the results files to your host machine with:
docker cp benchmarking_container:/ws/src/benchmarking_planners/pyre/benchmark/shelf_zero_test_results.db ./
docker cp benchmarking_container:/ws/src/benchmarking_planners/pyre/benchmark/shelf_height_test_results.db ./
docker cp benchmarking_container:/ws/src/benchmarking_planners/pyre/benchmark/shelf_height_rot_test_results.db ./
docker cp benchmarking_container:~/.ros/smpl_benchmarks ./
- Launch the visualization Jupyter notebook in
$(rospack find benchmarking_utils)/scripts/visualize
to plot the results. Relative symbolic links to the required logs paths are already present in this directory.
Additionally, you can load the aggregated results (*.db) files in Planner Arena to plot the results.
If you find this useful, please cite:
@inproceedings{sotirchos2024benchmarking,
title={Search-based versus Sampling-based Robot Motion Planning: A Comparative Study},
author={Georgios Sotirchos and Zlatan Ajanovic},
booktitle={ICAPS'24 Workshop on Planning and Robotics (PlanRob)},
year={2024}
}