You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

63 lines
3.4 KiB

2 years ago
  1. ![](../images/banner.png)
  2. ## Overview
  3. *stretch_description* provides materials for a [URDF](http://wiki.ros.org/urdf) kinematic model of the Stretch RE1 mobile manipulator from Hello Robot Inc.
  4. ## Details
  5. The *meshes directory* contains [STL mesh files](https://en.wikipedia.org/wiki/STL_(file_format)) representing the exterior geometry of various parts of the robot.
  6. The *urdf directory* contains [xacro files](http://wiki.ros.org/xacro) representing various parts of the robot that are used to generate the robot's URDF.
  7. stretch_ros expects a URDF with the name stretch.urdf to reside within the urdf directory. The file stretch.urdf serves as the URDF for the robot and must be generated. Typically, it is a calibrated urdf file for the particular Stretch RE1 robot being used. To generate this file, please read the documentation within stretch_ros/stretch_calibration.
  8. The xacro_to_urdf.sh will usually only be indirectly run as part of various scripts and launch files within stretch_ros/stretch_calibration.
  9. Sometimes a stretch_uncalibrated.urdf file will reside with the urdf directory. This file is typically generated directly from the xacro files without any alterations.
  10. ## Exporting a URDF
  11. Sometimes a URDF is useful outside of ROS, such as for simulations and analysis. Running the *export_urdf.sh* script in the urdf directory will export a full URDF model of the robot based on stretch.urdf.
  12. The exported URDF will be found within an exported_urdf directory. It is also copied to a directory for your specific robot found under ~/stretch_user. The exported URDF includes meshes and controller calibration YAML files. The exported URDF can be visualized using stretch_urdf_show.py, which is part of the stretch_body Python code.
  13. ## Changing the Tool
  14. If you wish to remove the default gripper and add a different tool, you will typically edit /stretch_description/urdf/stretch_description.xacro. Specifically, you will replace the following line in order to include the xacro for the new tool and then follow directions within stretch_ros/stretch_calibration to generate a new calibrated urdf file (stretch.urdf) that includes the new tool.
  15. `<xacro:include filename="stretch_gripper.xacro" />`
  16. As an example we provide the xacro `stretch_dry_erase_marker.xacro` and its dependent mesh files with stretch_ros.
  17. Some of the tools found in the [Stretch Body Tool Share](https://github.com/hello-robot/stretch_tool_share/) include URDF data. To integrate these tools into the URDF for your Stretch
  18. ```bash
  19. >>$ cd ~/repos
  20. >>$ git clone https://github.com/hello-robot/stretch_tool_share
  21. >>$ cd stretch_tool_share/<tool name>
  22. >>$ cp stretch_description/urdf/* ~/catkin_ws/src/stretch_ros/stretch_description/urdf/
  23. >>$ cp stretch_description/meshes/* ~/catkin_ws/src/stretch_ros/stretch_description/meshes/
  24. ```
  25. Next add the xacro for the particular tool to `/stretch_description/urdf/stretch_description.xacro`. Then you can generate and preview the uncalibrated URDF:
  26. ```bash
  27. >>$ cd ~/catkin_ws/src/stretch_ros/stretch_description/urdf
  28. >>$ cp stretch.urdf stretch.urdf.bak
  29. >>$ rosrun stretch_calibration update_urdf_after_xacro_change.sh
  30. ```
  31. Now visualize the new tool
  32. ```bash
  33. >>$ roslaunch stretch_calibration simple_test_head_calibration.launch
  34. ```
  35. ## License and Patents
  36. Patents are pending that cover aspects of the Stretch RE1 mobile manipulator.
  37. For license information, please see the LICENSE files.