In this project, we designed and implemented a completely autonomous system to perform reconnaissance in a simulated disaster environment. AprilTags were used as a proxy for victims in the simulated environment. The primary goals of this exercise were to map the unknown environment, localize the robot and accurately locate the AprilTags. A Turtlebot3 Burger was deployed to accomplish these tasks. The robot equipped with an array of sensors including LDS-01 LIDAR, a Raspberry Pi camera module V2 with Sony IMX219 8-megapixel sensor, and an IMU. Cartographer package was used to implement SLAM. To set up your turtlebot, follow the steps 3.1 to 3.3 on this website
-
The robot is connected to the host PC via SSH. Ensure that the turtlebot and the host PC are connected over the same network.
-
The host PC should also act as the ROS master for the system. To configure your system as the ROS master, follow the steps as below:
-
Open the bashrc on the host PC, and add the following lines:
export ROS_MASTER_URI=http://{IP ADDRESS OF HOST PC}:11311
export ROS_HOSTNAME={IP ADDRESS OF HOST PC}
-
Open the bashrc on the turtlebot, and add the following lines:
ROS_MASTER_URI=http://{IP ADDRESS OF HOST PC}:11311
ROS_HOSTNAME={IP ADDRESS OF TURTLEBOT}
-
-
To launch LIDAR, IMU and wheel encoder along with all rostopics, run (on turtlebot):
roslaunch turtlebot3_bringup turtlebot3_robot.launch
-
To launch the camera and the apriltag detection node, follow the steps as below (on turtlebot):
-
Launch the camera
roslaunch raspicam_node turtlebotics_camera.launch camera_frame_id:={YOUR DESIRED FRAME ID} image_topic:={YOUR IMAGE TOPIC} camera_info_topic:={YOUR CAMERA INFO TOPIC}
-
Launch the apriltag detection node
roslaunch apriltag_ros continuous_detection.launch image_topic:={YOUR IMAGE TOPIC} camera_info_topic:={YOUR CAMERA INFO TOPIC}
-
-
It is necessary that you add the camera link on your /tf topic as it is not added by default. To add your camera topic, run:
rosrun tf static_transform_publisher 0.03 0 0.1 0 0 0 base_link camera_frame 100
In this project, we have used cartographer to implement SLAM. It is necessary that you install cartographer package on your system by following the instructions on the official website
- Once your installation is complete, you need to update the
slam_methods
parameter tocartographer
in/opt/ros/noetic/share/turtlebot3_slam/launch/turtlebot3_slam.launch
We have used explore_lite for planning and exploration of the area.
-
To install explore_lite, run:
sudo apt install ros-${ROS_DISTRO}-multirobot-map-mergeros-${ROS_DISTRO}-explore-lite
Cartographer launches the move_base package by default which handles the path planning of the robot. Cartographer's map is probabilistic and its values range between {-1, [0-100]}. Now, explore_lite expects an integer map [-1, 0, 1] which denotes unknown, occupied, and unoccupied space respectively. To convert the probabilistic map of cartograher into the integer map, a custom node cartographer_remapping.py
is included in our ros package.
-
To launch the entire navigation and SLAM stack, run:
roslaunch turtlebot3_explore_env explore_env.launch
Once the turtlebot is deployed in the environment, and the navigation and SLAM node is launched, it is ready to detect tags and record the position of the apriltags in the environment. To handle this procedure, a custom node tag_tracker.py
is used. To run this node, run:
python3 tag_tracker.py
If the system is running as expected, you should be able to see the location of the apriltags in the Rviz environment. These poses are saved into a text file on completion of the reconnaisance
You can see that the generated probabilistic map is embedded with locations of AprilTags. The accuracy of detections was estimated to be between 20 to 30 cm.