Skip to content

Commit

Permalink
New README and v1.0.0!
Browse files Browse the repository at this point in the history
  • Loading branch information
gstavrinos committed Mar 4, 2019
1 parent 2e6efdc commit 376d501
Show file tree
Hide file tree
Showing 2 changed files with 35 additions and 22 deletions.
55 changes: 34 additions & 21 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,43 +10,41 @@ ez_pick_and_place allows you to pick and place any* object, without the hassle o



<sub>*given that you have a 3D model of it</sub>
<sub>* given that you have a 3D model of it</sub>

## How to use it

What you need to run:

TODO
* __Your arm and gripper hardware drivers or simulation.__ For our UR3 arm and Schunk PG70 gripper combo, the command for the simulated robot is: `roslaunch manos_gazebo manos_gazebo.launch limited:=true`

<!-- * Your arm's driver or simulation: For our UR3 arm the command is
* __Your arm and gripper MoveIt planning execution.__ For our UR3 arm and Schunk PG70 gripper combo, the command for the simulated robot is: `roslaunch manos_moveit_config manos_planning_execution.launch sim:=true limited:=true`

* Your gripper's driver or simulation
* __A GraspIt planning service.__ For our setup the command is: `roslaunch manos_graspit_config graspit_planning_service_opt.launch`

* Your arm's+gripper's MoveIt planning execution
* __ez_pick_and_place.__ A simple `rosrun ez_pick_and_place ez_pnp2.py` is enough.

* Your gripper's GraspIt planning service
* __(Optionally) rviz__ for MoveIt scene visualization. For our setup the command is: `roslaunch manos_moveit_config moveit_rviz.launch config:=true`

* ez_pick_and_place -->

With everything up and running ez_pick_and_place offers two services:
With everything up and running ez_pick_and_place provides two services:

* `EzSceneSetup` is used to setup the MoveIt and GraspIt planning scenes. Populating the EzSceneSetup request:

* `EzModel[] objects`/`EzModel[] obstacles`: Based on the `EzModel` message, you specify the name of your objects and obstacles, and where the model files for MoveIt and GraspIt can be found. The model files are different for MoveIt and GraspIt. We discuss this matter later in this doc. Finally, you have to specify the pose for each of your objects and obstacles.

* `EzModel gripper`: Based again on the `EzModel` message, you specify the gripper's name and the GraspIt file that accompanies it. The `move_file` field has no effect here.
* `EzModel gripper`: Based again on the `EzModel` message, you specify the gripper's name and the GraspIt file that accompanies it. The `moveit_file` field has no effect here.

* `string[] finger_joint_names`: Provide a string array containing the names of the gripper's finger joints.

* `string gripper_frame`: Provide the gripper's base_link.

* `float64 pose_factor`: Provide the factor difference between MoveIt and GraspIt. This should not be used under normal circumstances, but in case you are using a, exotic version of GraspIt, it is here to adapt to it.
* `float64 pose_factor`: Provide the factor difference between MoveIt and GraspIt. This should not be used under normal circumstances, but in case you are using an exotic version of GraspIt, it is here to adapt to it.

* `EzStartPlanning` is used to request a plan. Populating the EzStartPlanning request:

* `string graspit_target_object`: Provide the name of the object you previously added in the planning scene.

* `geometry_msgs/PoseStamped target_place`: The pose of the place location. Keep in mind that in v1.0.0 only the x and y of the position are taken into account. The algorithm assumes that the place surface is at the same height as the pick one, and complete disregards the orientation. If you are interested in how ez_pick_and_place works, reading the following section.
* `geometry_msgs/PoseStamped target_place`: The pose of the place location. Keep in mind that in v1.0.0 only the x and y of the position are taken into account. __The algorithm assumes that the place surface is at the same height as the pick one, and completely disregards the orientation (for now)__. We discuss later in this doc, how exactly ez_pick_and_place works.

* `string arm_move_group`: Provide the name of the arm move group.

Expand All @@ -59,15 +57,13 @@ For further info on how to use the package, you can refer to the `test2_ez_pnp2.

## How it works

So now you know how to use the package, but you are curious on how it works internally. Well, then this is the section for you.

ez_pick_and_place is a package that integrates MoveIt and GraspIt, to provide a much easier experience for the end user. When you set up your planning scene with all the obstacles and objects present, you can then request for an object to be picked and placed on a specific location.
ez_pick_and_place is a package that integrates MoveIt and GraspIt, to provide a much easier experience for the end user. When you set up your planning scene with all the obstacles and objects present, you can then request for an object to be picked and placed on a specific location.

When you make such request, the algorithm first makes a service call to the GraspIt planning process. After (quite) a while, GraspIt will return a series of candidate grasp poses.
When you make such request, the algorithm first makes a service call to the GraspIt planning service. After (quite) a while, GraspIt will return a series of candidate grasp poses.

The ez_pick_and_place algorithm first makes the necessary translations between the MoveIt and GraspIt worlds and then evaluates the translated candidate poses. As soon as a possible solution is found based on the inverse kinematics of a candidate grasp pose, ez_pick_and_place run the `pick()` function, which sends a series of commands to the robot that enables it to pick the requested object.
The ez_pick_and_place algorithm first makes the necessary translations between the MoveIt and GraspIt worlds and then evaluates the translated candidate poses. As soon as a possible solution is found based on the inverse kinematics of a candidate grasp pose, ez_pick_and_place runs the `pick()` function, which sends a series of commands to the robot that enables it to pick the requested object.

With the object picked by the robot, the algorithm starts computing the place pose, based on the location provided by the user. This step ensures that regardless of the arm's joints, the picked object's pitch and roll rotation is preserved. The algorithm generates arm poses that preserve the pitch and roll rotation of the object but not the yaw rotation, assuming that placing the object with the same way as it was picked will result in the object not falling over, since it will rest on its base. Apart from the _gyration_ (modification of the object's yaw), the algorithm experiments with a series of place heights too. Starting from the same height as the pick location and going as high as 5cm from the start one, the algorithm tries to find a place pose that has an inverse kinematics solution for both that height and gyration state. As soon as a solution is found, ez_pick_and_place runs the `place()` function, which sends a series of commands to the robot that enables it to place the object to the specified location.
With the object picked by the robot, the algorithm starts computing the place pose, based on the location provided by the user. This step ensures that, regardless of the arm's joints, the picked object's pitch and roll rotation is preserved. The algorithm generates arm poses that preserve the pitch and roll rotation of the object but not the yaw rotation, assuming that placing the object with the same way as it was picked will result in the object not falling over, since it will rest on its base. Apart from the _gyration_ (modification of the object's yaw), the algorithm experiments with a series of place heights too. Starting from the same height as the pick location and going as high as 5cm from the start one, the algorithm tries to find a place pose that has an inverse kinematics solution for both that height and gyration state. As soon as a solution is found, ez_pick_and_place runs the `place()` function, which sends a series of commands to the robot that enables it to place the object to the specified location.

For more geeky stuff, refer directly to the source code and especially the (lightly) documented `ez_tools.py` inside the `src` directory.

Expand All @@ -82,17 +78,34 @@ This section is here to redirect you to already awesome documentation regarding

## Creating 3D models for GraspIt and MoveIt

TODO
`Blender` is a fairly easy to use 3D modeling software. I am by no means an expert, but I can create basic 3D shapes and transform 3D models based on our needs.

Using Blender you can create and modify 3D models in order to make them useable both in MoveIt and GraspIt. Here is a list of steps to create or modify models in Blender (and beyond) for MoveIt and GraspIt integration:

* In order for your models to stay true to real-life objects in terms of size, it is recommended to enable Blender's length and angle unit systems. Also, make sure that the unit scale is set to 1.0, to make sure that the size you use in Blender will be the same as the one in the real world.
<img src="https://raw.githubusercontent.com/gstavrinos/ez_pick_and_place/master/doc/media/blender_units.png">

* The best way to resize your model is to use the `N` shortcut, which opens up the object transform sidebar. From there, you can specify the dimensions of your model in the units you selected earlier.
<img src="https://raw.githubusercontent.com/gstavrinos/ez_pick_and_place/master/doc/media/blender_transform_sidebar.png">

* Make sure the origin of your model is logically placed inside your model. It can be anywhere you like, but keep in mind that this will be the reference point of the object's pose later in your planning scene. In order to modify the origin of your model, press the (very convenient!) `Shift` + `Ctrl` + `Alt` + `C` shortcut. This shortcut will bring up a small menu from which the `Origin to Center of Mass (Surface)` option will, most of the times, be sufficient. Feel free to experiment though.
<img src="https://raw.githubusercontent.com/gstavrinos/ez_pick_and_place/master/doc/media/blender_set_origin.png">

* rViz and Gazebo requires .stl and .dae formats for your 3D models. I have had better luck with .stl files, if you don't require too complex colour schemes and textures for your models.

* In order for your models to be exactly the same in MoveIt and GraspIt, create a copy of your model, and make it 1000 times bigger for GraspIt integration. You can do this again from the transform sidebar (`N` shortcut) by either changing the scaling or the dimensions.

* GraspIt is compatible only with the .vi format. Blender cannot export .iv files, so export the larger copy of your model as .stl, and then convert it with the ivcon tool, by running `rosrun ivcon ivcon [input_filename].stl [output_filename].iv`.

## Recommendations, reminders and extra info

* In order for GraspIt to provide the algorithm with enough candidate grasp poses, we are using this [configuration file](https://github.com/Roboskel-Manipulation/manos_graspit_config/blob/master/config/graspit_planner_opt.yaml). You can experiment with your own based on your needs, but always refer to the one provided.
* In order for GraspIt to provide the algorithm with enough candidate grasp poses, we are using this [configuration file](https://github.com/Roboskel-Manipulation/manos_graspit_config/blob/master/config/graspit_planner_opt.yaml). You can experiment with your own configuration based on your needs, but always refer to the one provided.

* Under normal conditions, do not use the `pose_factor` field of the `EzSceneSetup` service.

* ALWAYS check the robot you have set up for GraspIt using the `graspit_simulator` commands, and then loading a default world with your robot.

* The best way I found to create the contact points was to edit my robot's description file, and not a method based on GUI since all of them seemed to crash on me. Depending on your gripper's complexity, this might be from fairly easy to pretty difficult...
* The best way I found to create the contact points was to manually edit my robot's description file, and not a method based on GUI since all of them seemed to crash on me. Depending on your gripper's complexity, this might be from fairly easy to pretty difficult...

* ALWAYS check your MoveIt objects using `rViz` to ensure that their size is the expected one.

Expand Down
2 changes: 1 addition & 1 deletion package.xml
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
<?xml version="1.0"?>
<package format="2">
<name>ez_pick_and_place</name>
<version>0.9.8</version>
<version>1.0.0</version>
<description>The ez_pick_and_place package</description>

<maintainer email="[email protected]">George Stavrinos</maintainer>
Expand Down

0 comments on commit 376d501

Please sign in to comment.