This repository contains a simulation for the Noah-bot robot. It contains an URDF model of the robot with visual meshes included, a Kinect camera, a laser sensor and a differential drive gazebo-ros plugin.
Packages where built to show how to use the robot to perform SLAM and navigate through an unknown or known map. Documentation on each individual package can be found in each one of them.
Developed in:
- Ubuntu 20.04
- ROS1 Noetic
- Gazebo 11
- Catkin
This project comes with a dockerfile for better portability. Keep in mind that if SLAM is ran while in the docker process, the database will be saved to a folder that's not mounted to the local machine, so when the docker process dies, the database generated from the SLAM will be lost.
- Install docker
- Clone this repository
- Place yourself in the docker folder inside the project:
cd <PROJECT>/docker
- Build the docker image:
docker build -t docker_noahbot .
- Run the script to run the docker image and mount the project. IMPORTANT: If the user does not own an nvidia gpu, delete the "
--gpus all \
" line
./run_docker
- Download dependencies for the packages
cd /home/catkin_ws
sudo apt-get update
rosdep install --from-paths src --ignore-src -r -y
- Build the project and source the workspace
cd /home/catkin_ws
catkin_make
source devel/setup.bash
- Launch one of the top level launchfiles!
- If the user wants to open more terminals inside the docker process, in a new terminal run:
docker exec -it noah_docker_process bash
source /opt/ros/noetic/setup.bash
source /home/catkin_ws/devel/setup.bash
Disclaimer: This has only been tested with the versions and software specified above. Running it with other versions is not guaranteed to work.
-
Clone this repository in the src folder of a catkin workspace
-
Place yourself in the catkin workspace. The folder structure should look like this:
<PATH>/catkin_ws/src/<REPOSITORY>
-
Download dependencies for the packages
rosdep install --from-paths src --ignore-src -r -y
- Build the project and source the workspace
catkin_make
source devel/setup.bash
- Launch one of the top level launchfiles!
-
Launch SLAM node to map a world. Can move the robot with goals or with the keyboard control node:
$ roslaunch noah_gazebo noah_slam.launch database_name:=<DATABASE_NAME>
-
Launch navigation node. Includes wayposes publisher node:
$ roslaunch noah_gazebo noah_navigation.launch map_name:=<MAP_NAME>
-
Launch mapless navigation node:
$ roslaunch noah_gazebo noah_navigation_mapless.launch
-
Launch keyboard control (useful to move robot when generating the SLAM):
$ roslaunch noah_control keyboard_teleop.launch
- willowgarage -> Comes included with Gazebo. No map generated.
- small_house -> Taken from AWS open repository. A SLAM generated map is provided for this map.
A map was generated for the "small_house" world using the SLAM Rtabmap package. This package creates a database from which the rtabmap.pgm and rtabmap.yaml files were taken. This files are used for the localization and move_base packages. The package stores the database in "~/.ros/rtabmap.db" (default location) from which the .pgm and .yaml can be extracted using the "database2pgm.sh" script located in "noah_rtabmap" package.
The user can specify the name of the database to be saved by passing the "database_name" argument to the slam launch file.
The user can specify the map in the navigation launch file by specifying the argument "map_name". Maps are located in the noah_2dnav package inside the maps folder. The default value is "rtabmap".
A package was created to publish a set of goals for the move_base_sequence node. The goals are defined in a .yaml file located in move_base_utils/mb_goals folder.