In this tutorial, we will create a mobile manipulator using a wheeled robot base and a robotic arm. All we need to do is to connect the arm_base link of the robot arm to the base_link of the robot.
data:image/s3,"s3://crabby-images/a4ba2/a4ba2679b6e8a5c79820660a6a1abd6cfdb074af" alt="mobile-manipulator-gif"
This tutorial would not have been possible without Ramkumar Gandhinathan and Lentin Joseph’s awesome book ROS Robotics Projects Second Edition (Disclosure: As an Amazon Associate I earn from qualifying purchases). I highly recommend it if you want to learn ROS 1. Many of the files (URDF, configuration, and STL files), come from their book’s public GitHub page.
Real-World Applications
This project has a number of real-world applications:
- Indoor Delivery Robots
- Order Fulfillment
- Factories
- Warehouses
- Space Exploration
- Power Plants
Let’s get started!
Prerequisites
- You have completed this tutorial where you learned how to create a mobile robot base.
- You have completed this tutorial where you learned how to create a robotic arm.
Build the Mobile Manipulator
Open a new terminal window.
Move to the urdf folder of your package.
roscd mobile_manipulator_body/urdf/
Now create a file named mobile_manipulator.urdf.
gedit mobile_manipulator.urdf
Add the mobile_manipulator.urdf code inside there.
Save and close the file.
Test the Mobile Manipulator
Now, let’s launch RViz to see what our robot looks like so far.
roscd mobile_manipulator_body/urdf/
roslaunch urdf_tutorial display.launch model:=mobile_manipulator.urdf
data:image/s3,"s3://crabby-images/09f41/09f413cdb9fa7e6712e25549f75f33072fdcce3b" alt="1-rviz-mobile-manipulator"
A GUI will appear that will enable you to move the joints.
data:image/s3,"s3://crabby-images/ba5ca/ba5ca9e4c8f6ea2818be1ab98c22165f7863f622" alt="2-gui-will-appear"
Launch the Mobile Manipulator
Now let’s launch the mobile manipulator.
Open a new terminal window, and go to the package.
roscd mobile_manipulator_body/launch/
Create a new launch file.
gedit mobile_manipulator_gazebo.launch
Add the mobile_manipulator_gazebo.launch code inside there.
Save and close the file.
Now let’s launch the robot in Gazebo.
Move to your catkin workspace.
cd ~/catkin_ws/
roslaunch mobile_manipulator_body mobile_manipulator_gazebo.launch
Here is how the robot looks.
data:image/s3,"s3://crabby-images/43b67/43b67ea8099614225e4a3613311b4552520dfaa1" alt="3-gazebo-mobile-manipulator"
Here are the active ROS topics.
rostopic list
data:image/s3,"s3://crabby-images/6f123/6f12372aa3e19d1db6e263ab3854abee18ea130c" alt="4-ros-active-topics"
Open a new terminal, and type this command to move the robot arm a little bit:
rostopic pub /arm_controller/command trajectory_msgs/JointTrajectory '{joint_names: ["arm_base_joint","shoulder_joint", "bottom_wrist_joint", "elbow_joint","top_wrist_joint"], points: [{positions: [-0.1, 0.5, 0.02, 0, 0], time_from_start: [1,0]}]}' -1
Type this command to bring the robot back to the home position.
rostopic pub /arm_controller/command trajectory_msgs/JointTrajectory '{joint_names: ["arm_base_joint","shoulder_joint", "bottom_wrist_joint", "elbow_joint","top_wrist_joint"], points: [{positions: [0, 0, 0, 0, 0], time_from_start: [1,0]}]}' -1
data:image/s3,"s3://crabby-images/6ac21/6ac21680bcefad560633e38dd4bfacefaa46d099" alt="3b-gazebo-mobile-manipulator"
You can steer the robot by opening a new window and typing:
rosrun rqt_robot_steering rqt_robot_steering
You will need to change the topic inside the GUI to:
/robot_base_velocity_controller/cmd_vel
To see the velocity messages, open a new window and type:
rostopic echo /robot_base_velocity_controller/cmd_vel