In the previous tutorial, we built a simulated mobile robot base from scratch. Now I want to create a robotic arm that I will eventually attach to this base so that I have a complete mobile manipulator. Here is what we will build:
data:image/s3,"s3://crabby-images/05390/053901608689956a87896dcc4b70e2d79f6ad0cf" alt="robot-arm-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.
Build the Robot Arm
Open a new terminal window.
Move to the urdf folder of your package.
roscd mobile_manipulator_body/urdf/
Now create a file named robot_arm.urdf.
gedit robot_arm.urdf
Add the robot_arm.urdf code inside there.
Save and close the file.
Test the Robot Arm
Now let’s launch the robot arm.
Open a new terminal window, and go to the package.
roscd mobile_manipulator_body/urdf/
roslaunch urdf_tutorial display.launch model:=robot_arm.urdf
Change the Fixed Frame to world.
Here is how the robot looks.
data:image/s3,"s3://crabby-images/e3672/e3672a15ee1930b6b83ce5415e7eaeba9c42c2aa" alt="1-robot-arm-launch-test-1"
Move the arm using the sliders.
data:image/s3,"s3://crabby-images/7f0c5/7f0c509f7b4b9b263067a0e285f6249cf43432fd" alt="2-sliders"
Here are the active ROS topics.
rostopic list
data:image/s3,"s3://crabby-images/48af5/48af53fb4ca98f089930e7611b6bdf266c2b3dc6" alt="1a-rostopic-list"
Press CTRL + C in all open terminal windows to close everything down.
Now, let’s set up the configuration parameters for the controllers.
Open a new terminal window.
Go to the config file of your package.
roscd mobile_manipulator_body/config/
Now create a file named arm_control.yaml.
gedit arm_control.yaml
Add the arm_control.yaml code inside there.
Save and close the file.
Now create a file named joint_state_controller.yaml.
gedit joint_state_controller.yaml
Add the joint_state_controller.yaml code inside there.
Save and close the file.
Launch the Robot Arm
Now let’s launch the robot arm.
Open a new terminal window, and go to the package.
roscd mobile_manipulator_body/launch/
Create a new launch file.
gedit arm_gazebo_control.launch
Add the arm_gazebo_control.launch code inside there.
Save and close the file.
Now let’s launch the robot in Gazebo.
Open a new terminal window.
Move to your catkin workspace.
cd ~/catkin_ws/
roslaunch mobile_manipulator_body arm_gazebo_control.launch
Here is how the robot arm looks.
data:image/s3,"s3://crabby-images/4de81/4de81de18b599efcca057ab25b794f0ac429e1c8" alt="4-robot-arm-gazebo"
Here are the active ROS topics.
rostopic list
data:image/s3,"s3://crabby-images/cf726/cf7265364bdae1cae1b6577f9e8d3dff48d81513" alt="5-ros-topic-list"
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
data:image/s3,"s3://crabby-images/d9a33/d9a337286fcada4b8dc4ae90a3d3ea72bc50239a" alt="6-after-publishing-command"
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
References
ROS Robotics Projects Second Edition