From 552e3a6cb47d77a681705c763bc956f9613f5f64 Mon Sep 17 00:00:00 2001 From: Dharini Dutia Date: Thu, 31 Aug 2023 00:18:20 -0700 Subject: [PATCH] Apply suggestions from code review Co-authored-by: Mabel Zhang Signed-off-by: Dharini Dutia --- garden/ros2_gazebo_integration_tutorial.md | 28 ++++++++++------------ garden/ros_gz_project_template_guide.md | 17 +++++++------ 2 files changed, 20 insertions(+), 25 deletions(-) diff --git a/garden/ros2_gazebo_integration_tutorial.md b/garden/ros2_gazebo_integration_tutorial.md index 7300d7f3f..d41294bc7 100644 --- a/garden/ros2_gazebo_integration_tutorial.md +++ b/garden/ros2_gazebo_integration_tutorial.md @@ -16,7 +16,7 @@ Users can interact with `rrbot` through ROS 2 commands to move the robot's arms ## Setup -Start a fresh ROS 2 launch file or add the following nodes in your project's main launch file. We aim to achieve: +Start a fresh ROS 2 Python launch file or add the following nodes in your project's main launch file. We aim to achieve: 1. A robot model development and test setup 1. Configure RViz (and other ROS 2 tools) to control a robot model simulated by a Gazebo world @@ -41,8 +41,7 @@ For publishing and controlling the robot pose, we need joint states of the robot ![jsp](tutorials/ros2_integration/jsp_diagram.jpg) 1. The `joint_state_publisher` reads the `robot_description` parameter from the parameter server, finds all of the non-fixed joints and publishes a [JointState](https://docs.ros.org/en/api/sensor_msgs/html/msg/JointState.html) message with all those joints defined. - -```python + ```python joint_state_publisher_gui = Node( package='joint_state_publisher_gui', executable='joint_state_publisher_gui', @@ -53,15 +52,12 @@ For publishing and controlling the robot pose, we need joint states of the robot ``` 1. Visualize in RViz and with the help of the `joint_state_publisher_gui`, configure your robot model. See [documentation](https://wiki.ros.org/joint_state_publisher?distro=noetic) for node API. - -This functionality is useful during initial development of the model. Afterwards, once you've set up simulation, it might be less useful. -At this point we have achieved the first aim defined in [Setup](#Setup). - + This functionality is useful during initial development of the model. Afterwards, once you've set up simulation, it might be less useful. + At this point we have achieved the first aim defined in [Setup](#Setup). 1. Now if you'd want to extend this to visualize robot motion, we need positions and transforms. The `robot_state_publisher` takes the description and joint angles of the robot as inputs and publishes the 3D poses of the robot links, using a kinematic tree model of the robot. - -```python + ```python robot_state_publisher = Node( package='robot_state_publisher', executable='robot_state_publisher', @@ -73,12 +69,11 @@ The `robot_state_publisher` takes the description and joint angles of the robot ] ) ``` - -These 3D poses are published on the `/tf` topic which is useful to track/plan robot's motion, communicate between different parts of the robot or evaluate robot's performance. + These 3D poses are published on the `/tf` topic which is useful to track/plan robot's motion, communicate between different parts of the robot or evaluate robot's performance. ### Configure a communication bridge -These joint states can either come from `joint_state_publisher` as seen earlier or from simulated [JointStatePub](https://gazebosim.org/api/gazebo/4.5/classignition_1_1gazebo_1_1systems_1_1JointStatePublisher.html#details) system's joint_state message. +These joint states can either come from `joint_state_publisher` as seen earlier or from simulated [JointStatePub](https://gazebosim.org/api/gazebo/4.5/classignition_1_1gazebo_1_1systems_1_1JointStatePublisher.html#details) system's `joint_state` message. Configure a bridge between ROS topic `/joint_states` and Gazebo topic `/world/demo/model/diff_drive/joint_state` by adding remappings in the node setup or by creating a bridge.yaml: @@ -94,11 +89,12 @@ Learn more about the bridge from [ROS 2 Integration](docs/garden/ros2_integratio ### Maintaining a single robot description format -Main pain point of using existing simulation assets with ROS 2 tools is updating URDF files into Gazebo readable format, out of scope for this tutorial, is no longer required. If you are maintaining a URDF and an SDF file in a project, you can now drop the URDF and just use SDF for both ROS and Gazebo. -This is made possible by `sdformat_urdf`, parser plugin library that converts an SDF file to URDF C++ DOM structures, making it understandle by the ROS 2 ecosystem. -Though there are some limitations of the plugin like not all SDFormat tags are compatible, for example if you have any sensors attached to a joint, it won't be parsed. More details [here](https://github.com/ros/sdformat_urdf/tree/ros2/sdformat_urdf). +The main pain point of using existing simulation assets with ROS 2 tools was updating URDF files into a Gazebo-readable format. This is no longer required. If you are maintaining a URDF and an SDF file in a project, you can now drop the URDF and just use the SDF for both ROS and Gazebo. + +This is made possible by `sdformat_urdf`, a parser plugin library that converts an SDF file to URDF C++ DOM structures, making it understandle by the ROS 2 ecosystem. +Though there are some limitations of the plugin like not all SDFormat tags are compatible. For example, if you have any sensors attached to a joint, it won't be parsed. More details [here](https://github.com/ros/sdformat_urdf/tree/ros2/sdformat_urdf). -To embed this functionality, we simply need to print the SDFormat file to `/robot_description` ROS topic and internally it'll find a suitable parser, `sdformat_urdf` in this case, to read the file. This is already done while configuring the `robot_state_publisher` earlier. +To embed this functionality, we simply need to print the SDFormat file to the `/robot_description` ROS topic, and internally ROS will find a suitable parser, `sdformat_urdf` in this case, to read the file. This is already done while configuring the `robot_state_publisher` earlier. ### Run RViz and Gazebo diff --git a/garden/ros_gz_project_template_guide.md b/garden/ros_gz_project_template_guide.md index 7c499b078..e29fa28b3 100644 --- a/garden/ros_gz_project_template_guide.md +++ b/garden/ros_gz_project_template_guide.md @@ -4,18 +4,17 @@ In this guide, you will learn how to use the `ros_gz_project_template` to create ## Installation Steps -1. If you are starting a project, create new workspace or go to your existing project's source directory: +1. If you are starting a project, create a new workspace or go to your existing project's source directory: -```bash + ```bash mkdir -p ~/project_ws/src cd ~/project_ws/src -``` -1. Directly `Use this template` and create your project repository on Github. +1. Directly use the [`ros_gz_project_template` template](https://github.com/gazebosim/ros_gz_project_template) and create your project repository on GitHub. ![use_template](tutorials/ros2_integration/use_template.png) - Or start by cloning the `ros_gz_project_template` repository: + Or start by cloning the template repository: ```bash wget https://raw.githubusercontent.com/gazebosim/ros_gz_project_template/main/template_workspace.yaml @@ -36,13 +35,13 @@ In this guide, you will learn how to use the `ros_gz_project_template` to create ## Package structure -At this point you'll have the following packages in your project workspace: +At this point you'll have the following packages in your project: -* `ros_gz_example_description` - holds the sdf description of the simulated system and any other simulation assets. +* `ros_gz_example_description` - holds the SDF description of the simulated system and any other simulation assets. Simulation assets means your models or robot descriptions in URDF or SDF, meshes and materials files to help visualize different parts of the robot and finally compiling all these elements in a simulated world SDF. Existing assets can be used by installing the models directory and exporting the paths to your environment. Setting up paths can be also automated using ament environment hooks with a DSV file prepending the model share path to Gazebo resource path. -* `ros_gz_example_gazebo` - holds gazebo specific code and configurations. Namely this is where user-defined worlds and custom systems end up. +* `ros_gz_example_gazebo` - holds Gazebo specific code and configurations. Namely this is where user-defined worlds and custom system plugins end up. * `ros_gz_example_application` - holds ROS 2 specific code and configurations. Namely where control, planning or any high level algoritms reside. @@ -69,7 +68,7 @@ Setting up paths can be also automated using ament environment hooks with a DSV Explore the `src/your_project_name` directory to add/modify the packages associated with your project. There are two primary mechanisms to integrate ROS 2 and Gazebo depending on your application: - 1. Use ros_gz_bridge to dynamically connect topics between ROS 2 and Gazebo (which is demonstrated as an example in this template) + 1. Use [ros_gz_bridge](https://github.com/gazebosim/ros_gz) to dynamically connect topics between ROS 2 and Gazebo (which is demonstrated as an example in this template) 1. Embed ROS 2 directly in a Gazebo system plugin 1. Build