- Getting familiar with ROS 2 workflow
- Understanding how to create nodes with publishers, subscribers
- Understanding ROS 2 package structure, files, dependenciees
- Creating launch files
It's highly recommended to install Ubuntu natively on your machine for developement in simulation. However, if it's impossible for you to do so, you can still use the simulation inside Docker containers. In the following instructions, if you have Ubuntu installed natively, ignore directions for using Docker.
The goal of this lab is to get you familiar with the ROS 2 workflow. You'll have the option to complete the coding segment of this assignment in either Python or C++. However, we highly recommend trying out both since this will be the easiest assignment to get started on a new language, and the workflow in these two languages are slightly different in ROS2 and it's beneficial to understand both.
In this lab, it'll be helpful to read these tutorials if you're stuck:
https://docs.ros.org/en/humble/Tutorials.html
https://roboticsbackend.com/category/ros2/
Install ROS 2 following the instructions here: https://docs.ros.org/en/humble/Installation.html.
Next, create a workspace:
mkdir -p ~/lab1_ws/src
cd lab1_ws
colcon build
Move on to Section 3 once you're done.
Now that we have the access to a ROS 2 environment, let's test out the basic ROS 2 commands. In the terminal, run:
source /opt/ros/humble/setup.bash
ros2 topic list
You should see two topics listed:
/parameter_events
/rosout
If you need multiple terminals and you're inside a Docker container, use tmux
.
Deliverable 1: create a package named lab1_pkg
in the workspace we created. The package needs to meet these criteria:
- The package supports both
Python
andC++
. - The package needs to have the
ackermann_msgs
dependency. - Both of these can be done by declaring the correct dependencies in
package.xml
. - If declared properly the depencies could be installed using
rosdep
. - Your package folder should be neat. You shouldn't have multiple 'src' folders or unnecessary 'install' or 'build' folders.
Deliverable 2: create two nodes in the package we just created. You can use either Python
or C++
for these nodes.
The first node will be named talker.cpp
or talker.py
and needs to meet these criteria:
talker
listens to two ROS parametersv
andd
.talker
publishes anAckermannDriveStamped
message with thespeed
field equal to thev
parameter andsteering_angle
field equal to thed
parameter, and to a topic nameddrive
.talker
publishes as fast as possible.- To test node, set the two ROS parameters through command line, a launch file, or a yaml file.
The second node will be named relay.cpp
or relay.py
and needs to meet these criteria:
relay
subscribes to thedrive
topic.- In the subscriber callback, take the speed and steering angle from the incoming message, multiply both by 3, and publish the new values via another
AckermannDriveStamped
message to a topic nameddrive_relay
.
Deliverable 3: create a launch file lab1_launch.py
that launches both of the nodes we've created. If you want, you could also set the parameter for the talker
node in this launch file.
After you've finished all the deliverables, launch the two nodes and test out these ROS 2 commands:
ros2 topic list
ros2 topic info drive
ros2 topic echo drive
ros2 node list
ros2 node info talker
ros2 node info relay
In addition to the three deliverables described in this document, fill in the answers to the questions listed in SUBMISSION.md
.
We'll be using Github classroom throughout the semester to manage submissions for lab assignments. After you're finished, directly commit and push to the repo Github classroom created for you.
- Correctly creating the package: 25 Points
- Correctly creating the nodes: 25 Points
- Correctly creating the launch file: 25 Points
- Written questions: 25 Points