-
Notifications
You must be signed in to change notification settings - Fork 70
Bimanual Manipulation Setup and Examples
This example demonstrates three key developments
- Configuring an arbitrary arm for MoveIt and Gazebo
- Launch two robots in an environment as well as move_group modification
- Add and configure two arms for REXROV then demonstrate key movements
MoveIt is an open-source project that provides the tools to develop complex manipulation scenarios. It integrates a number of motion planning libraries. MoveIt runs on top of ROS and builds on ROS functionality.
Configuring an arm for MoveIt is made simpler by using the MoveIt Setup Assistant. For our example, we followed the ROS Industrial/Universal Robot format for our robot *.urdf
files. We found that by adopting this structure over the UUV Simulator structure allowed for greater customization and easier non-MoveIt configurations and sensor additions.
The process for configuring an arm is as follows, with files located in the uuv_manipulators/oberon7
sub-directories:
- Start the MoveIt Setup Assistant. This will generate the MoveIt configuration files for planners, collision checking, pick-and-place infrastructure, joystick teleoperation, and predetermined poses. The robot will not be controllable in Gazebo as no ROS controllers will exist, only "fake" MoveIt controllers.
- Create the ros controllers. These must be done "by hand" and are specific to the robot. For the Gazebo side, we created three files:
joint_state_controller.yaml
,arm_controller.yaml
, andhand_controller.yaml
. - Create a launch file to start all of these controllers. In our case, this launch file is
oberon7.launch
and includes a node to load ROS controllers.
After configuring one arm, we can make small modifications to allow for N arms in a simulation. In this example, we add group namespaces to several files to allow us to add two arms to one simulation while not having to generate separate controller files.
To start the Gazebo simulation in an empty world, run
roslaunch dave_demo_launch dave_two_arm_demo.launch
Once the controllers have loaded it is safe to start the MoveIt move group and RViz
roslaunch oberon7_moveit_config oberon7_multi_planning_execution.launch
Because we are treating each arm as a separate robot, this will bring up two RViz windows. Each robot can accept and execute a motion plan simultaneously, but are not aware of each other in terms of collision avoidance.
In each of the two launch files for this example we added a group ns
. This allows us to differentiate between the two arms, add a starting pose, define a parent to connect the arms to, and load ros controllers under each namespace in oberon7_multi.launch
.
From dave_two_arm_demo.launch
<group ns="robot1">
<include file="$(find oberon7_gazebo)/launch/oberon7_multi.launch">
<arg name="xyzpos" value="0.0 0.0 2.0"/>
<arg name="parent" value="$(arg parent)"/>
<arg name="robot_name" value="robot1"/>
...
From oberon7_multi_planning_execution.launch
<group ns="robot1">
<arg name="moveit_controller_manager" default="oberon7" />
...
<include file="$(find oberon7_moveit_config)/launch/move_group.launch">
...
There are multiple ways of generating poses for each arm. For this demo we consider three of them, all of which require RViz.
- Random goal pose
- Pre-saved poses
- Drag group end-effector
To choose a random goal pose, for an arm in RViz choose <random valid>
in the "Goal State" drop down menu. Similarly, saved poses are avaiable under the "Start State" and "Goal State" drop down menus. To switch to the gripper, choose hand
from the "Planning Group" drop down. The end effector can be more specifically moved by clicking and holding the highlighted coordinate frame and simply dragging it to the position you want the arm to move to.
Adding two controllable arms to another robot requires a different solution to the group ns
solution outlined above. In this case, the oberon7 xacro files were modified to accept a namespace value. This namespace is reflected in the controllers required to run each arm. There are pros and cons to this setup as well.
Starting the Gazebo simulation in the dave_ocean_waves.world
world.
roslaunch dave_demo_launch dave_oberon7_moveit.launch
Once the simulation has started and controllers have been loaded, the MoveIt interface can be started along with RViz. Starting this prematurely will result in the example not working.
roslaunch rexrov_oberon7_moveit rexrov_dual_arm_moveit_planning_execution.launch moveit_controller_manager:=rexrov
The arms on the REXROV operate similarly to the independent Oberon7 arms in the previous example, despite significant differences in controllers and configuration. The easiest way to move them is via RViz or joystick_control.launch
. However, for more advanced control, a ROS node can be created.
This demo uses a ROS node to call the MoveIt move_groups to actuate each of the grippers and each of the arms. The code also demonstrates different methods for acquiring the pose of an object in coordinates that can be passed directly to the gripper.
To run the demo, we follow the same procedure as above then run the node. Start by launch Gazebo and controllers
roslaunch dave_demo_launch dave_oberon7_moveit.launch
Once controllers are loaded and Gazebo is running launch MoveIt and RViz with
roslaunch rexrov_oberon7_moveit rexrov_dual_arm_moveit_planning_execution.launch moveit_controller_manager:=rexrov
Once RViz is loaded, you can run the node
rosrun dave_nodes bimanual_simple_demo.py
The result show each gripper opening and closing, and each arm extending and returning to a home position.
Notes:
- It is possible to control multiple arms simultaneously by adding move_groups to a new "umbrella" move_group. When this move_group is called, collision checking is disabled between arms. Multi-Group MoveIt Tutorial PR