Skip to content

Latest commit

 

History

History
301 lines (220 loc) · 12.2 KB

README.md

File metadata and controls

301 lines (220 loc) · 12.2 KB

header

Important

❗An error of missing ros_node_interface pakcage was fixed at 2024-07-15-14:00.

Note

Address of this repository was changed from https://github.com/yongjunshin/sdi_turtlebot3_toy_app_ws.git to https://github.com/open-SDI/sdi_turtlebot3_toy_app_ws.git, but DON'T WORRY because the previous address still works!

Table of contents

1. Introduction

This is a workspace of ROS2 turtlebot3 toy application for SDI project.

This toy application is designed

  • to provide a reusable source skeleton of a ROS2 python application for robot mobility (e.g., turtlebot3),
  • to show blueprints of robot mobility software based on the Autoware project,
  • to facilliate study about the concept of ROS2 and Autoware, and
  • last but not least, to provide a working dummy mobility application for collaboration between research partners of SDI project.

2. Design

Toy application design (in ROS graph form)

In this section, we briefly introduce three key concepts of the design of this toy application.

Autoware

Our toy application mimics the autonomous driving system architecture of Autoware. Autoware's autonomous driving system architecture consists of 7 core modules. Each module corresponds to its own ROS package. To utilize turtlebot3, we reuse the ROS2 nodes provided by turtlebot3 for the sensing, vehicle interface, and map modules.

Dummy ROS nodes

We provide our own toy ROS2 nodes for the localization, perception, planning, and control modules. The nodes included in the toy application are working dummy nodes that do not provide full autonomous driving functionality. Currently, as an example, they only reference image and lidar data, and most of the outputs from each node are simple strings. However, the flow of the nodes reflects Autoware's design and is useful for understanding the basic flow of ROS2 and Autoware in a simple manner. This can be expanded to develop a real application based on Autoware. For more information, refer to the Autoware design documentation.

Simple user interface nodes

An autonomous driving system can provide a user interface to the user. Therefore, we provide user interface ROS nodes (i.e., service and action clients) that express several predictable scenarios. 1) /my_object_detection_service: returns a list of objects recognized by the robot to the user, 2) /my_destination_action: user requests a destination they want to go to, 3) /my_emergency_service: switches to manual driving in case of an emergency. These nodes are also working dummy nodes.

3. Workspace structure

 📂sdi_turtlebot3_toy_app_ws    # ROS2 workspace
 ┣ 📂src
 ┃ ┣ 📦bringing_up                # ROS2 pakcage
 ┃ ┃ ┣ 📂launch
 ┃ ┃ ┃ ┗ 📜my_toy_bringing_up.launch.py
 ┃ ┃ ┣ 📂param
 ┃ ┃ ┃ ┗ 📜my_toy_bringing_up_config.yaml
 ┃ ┃ ┣ 📂bringing_up
 ┃ ┃ ┣ 📜package.xml
 ┃ ┃ ┗ 📜setup.py
 ┃ ┣ 📦ros_node_interface         # ROS2 pakcage
 ┃ ┃ ┣ 📂action
 ┃ ┃ ┃ ┗ 📜Destination.action
 ┃ ┃ ┣ 📂msg
 ┃ ┃ ┣ 📂srv
 ┃ ┃ ┃ ┣ 📜EmergencyControl.srv
 ┃ ┃ ┃ ┗ 📜ObjectDetection.srv
 ┃ ┃ ┣ 📜CMakeLists.txt
 ┃ ┃ ┗ 📜package.xml
 ┃ ┣ 📦localization               # ROS2 pakcage, Autoware module
 ┃ ┃ ┣ 📂launch
 ┃ ┃ ┃ ┗ 📜my_localization.launch.py
 ┃ ┃ ┣ 📂param
 ┃ ┃ ┃ ┗ 📜my_localization_config.yaml
 ┃ ┃ ┣ 📂localization
 ┃ ┃ ┃ ┗ 📜my_lidar_localization.py
 ┃ ┃ ┣ 📜package.xml
 ┃ ┃ ┗ 📜setup.py
 ┃ ┣ 📦perception                 # ROS2 pakcage, Autoware module
 ┃ ┃ ┣ 📂launch
 ┃ ┃ ┃ ┗ 📜my_perception.launch.py
 ┃ ┃ ┣ 📂param
 ┃ ┃ ┃ ┗ 📜my_perception_config.yaml
 ┃ ┃ ┣ 📂perception
 ┃ ┃ ┃ ┣ 📜my_camera_perception.py
 ┃ ┃ ┃ ┣ 📜my_lidar_perception.py
 ┃ ┃ ┃ ┗ 📜my_object_detection_service.py
 ┃ ┃ ┣ 📜package.xml
 ┃ ┃ ┗ 📜setup.py
 ┃ ┣ 📦planning                   # ROS2 pakcage, Autoware module
 ┃ ┃ ┣ 📂launch
 ┃ ┃ ┃ ┗ 📜my_planning.launch.py
 ┃ ┃ ┣ 📂param
 ┃ ┃ ┃ ┗ 📜my_planning_config.yaml
 ┃ ┃ ┣ 📂planning
 ┃ ┃ ┃ ┣ 📜my_destination_action.py
 ┃ ┃ ┃ ┗ 📜my_planning.py
 ┃ ┃ ┣ 📜package.xml
 ┃ ┃ ┗ 📜setup.py
 ┃ ┣ 📦control                    # ROS2 pakcage, Autoware module
 ┃ ┃ ┣ 📂launch
 ┃ ┃ ┃ ┗ 📜my_control.launch.py
 ┃ ┃ ┣ 📂param
 ┃ ┃ ┃ ┗ 📜my_control_config.yaml
 ┃ ┃ ┣ 📂control
 ┃ ┃ ┃ ┣ 📜my_control.py
 ┃ ┃ ┃ ┗ 📜my_emergency_service.py
 ┃ ┃ ┣ 📜package.xml
 ┃ ┃ ┗ 📜setup.py
 ┃ ┣ 📂map                        # Autoware module
 ┃ ┃ ┣ 📜sample_map_house.pgm
 ┃ ┃ ┣ 📜sample_map_house.yaml
 ┃ ┃ ┣ 📜sample_map_turtle.pgm
 ┃ ┃ ┗ 📜sample_map_turtle.yaml
 ┣ 📂build                        # will be generated after build
 ┣ 📂install                      # will be generated after build
 ┗ 📂log                          # will be generated after build

4. Prerequisite

While this repository is a standalone ROS2 workspace that can be built and run without Turtlebot3, it is recommended to run it with Turtlebot3 simulation or a real device.

This toy application depends on the following:

Make sure you install and build the above dependencies.

This instruction does not cover manuals for the above dependencies. If you have satisfied all prerequisites, you should be able to successfully follow all steps of the following Turtlebot3-ROS2-Gazebo tutorials:

After following these tutorials, you should see your Turtlebot3 working in your real or virtual world.

5. Build

Follow the steps to build our toy application.

  1. Clone our toy application workspace.
xxx@xxx:{your_path}$   git clone https://github.com/open-SDI/sdi_turtlebot3_toy_app_ws.git
  1. Build all packages in the workspacae
xxx@xxx:{your_path}$   cd sdi_turtlebot3_toy_app_ws
xxx@xxx:{your_path}/sdi_turtlebot3_toy_app_ws$     colcon build --symlink-install

This will show following outputs, and make "build", "install", and "log" directories.

xxx@xxx:{your_path}/sdi_turtlebot3_toy_app_ws$ colcon build --symlink-install
Starting >>> ros_node_interface
Starting >>> bringing_up
Finished <<< ros_node_interface [0.22s]                                     
Starting >>> control
Starting >>> localization
Starting >>> perception
Starting >>> planning
Finished <<< bringing_up [0.81s]                                           
Finished <<< control [0.76s]                                                
Finished <<< perception [0.76s]
Finished <<< planning [0.76s]
Finished <<< localization [0.77s]

Summary: 6 packages finished [1.11s]
  1. Source the setup files

After build, you must run install/local_setup.bash for every terminal before you run ROS applications.

xxx@xxx:{your_path}/sdi_turtlebot3_toy_app_ws$     source ./install/local_setup.bash

We recommend you to add sourcing to your shell startup script. Refer this.

6. Run

Before running our toy application, first run the turtlebot3 application in a virtual or real world, as you did in prerequisite section.

There are multiple ways to run applications in ROS2 (e.g., launch, run, etc.).

Here, we introduce two simple ways to launch our toy application: "quick start" and "debug". Both methods result in the same final state.

In addition, a manual to run "User interface nodes" is seperately proivded.

Quick start

To quickly bring up all toy application nodes at once, launch the "bringing up".

Note: The "bringing up" package is a popular approach in ROS projects. It includes launch files for execution scenarios that use multiple ROS nodes spread across several packages.

  1. Launch my_toy_bringing_up.launch.py in the workspace.
xxx@xxx:{your_path}/sdi_turtlebot3_toy_app_ws$     ros2 launch bringing_up my_toy_bringing_up.launch.py

Debug

To carefully examine the logs of different modules in separate terminals, execute launch files for each package in different terminals.

  1. Launch my_localization.launch.py in the workspace.
xxx@xxx:{your_path}/sdi_turtlebot3_toy_app_ws$     ros2 launch localization my_localization.launch.py
  1. Launch my_perception.launch.py in the workspace.
xxx@xxx:{your_path}/sdi_turtlebot3_toy_app_ws$     ros2 launch perception my_perception.launch.py
  1. Launch my_planning.launch.py in the workspace.
xxx@xxx:{your_path}/sdi_turtlebot3_toy_app_ws$     ros2 launch planning my_planning.launch.py
  1. Launch my_control.launch.py in the workspace.
xxx@xxx:{your_path}/sdi_turtlebot3_toy_app_ws$     ros2 launch control my_control.launch.py

If you want to delve deeper, you can manually run all ROS nodes defined in our workspace one by one without using launch files. This can be done using the ros2 run ... command.

User interface nodes

There are also three user interface nodes: perception/my_object_detection_service.py, planning/my_destination_action.py, and control/my_emergency_service.py.

You can run each of them in different terminals when above launches are running.

xxx@xxx:{your_path}/sdi_turtlebot3_toy_app_ws$     ros2 run perception my_object_detection_service
xxx@xxx:{your_path}/sdi_turtlebot3_toy_app_ws$     ros2 run planning my_destination_action
xxx@xxx:{your_path}/sdi_turtlebot3_toy_app_ws$     ros2 run control my_emergency_service

Current interface nodes are dummy nodes, so gets random or arbitrary inputs. Please check their short dummy codes.

7. Result

Checking rqt_graph is one of the simplest ways to see the status of our toy application.

xxx@xxx:{your_path}/sdi_turtlebot3_toy_app_ws$     rqt-graph

ROS graph of running toy application

You can see that the result of rqt_graph corresponds to the design of toy application.

8. Final remarks

You have an awesome running dummy toy application that covers ROS2, Autoware, and Turtlebot3.

This repository works as a skeleton code base, so it may be kept as simple as possible without adding many fancy functions in the future. Despite this, any issues, pull requests, or suggestions for improvement are welcome.

Now, you can extend this toy application for your own purposes. Enjoy exploring and developing! 😉

Contact to authors