ROS (Robot Operating System) is a flexible framework for writing robot software. It provides a wide range of tools, libraries, and conventions to help you build complex robot applications. ROS is not an operating system in the traditional sense; rather, it provides services designed for heterogeneous computer clusters, and it aims to simplify code reuse between robotics projects.
ROS follows a distributed computing architecture, where nodes communicate with each other via topics, services, and actions. Nodes are processes that perform computation, while topics are named buses over which nodes exchange messages. Services allow nodes to send requests and receive responses, and actions provide a way to execute long-running tasks asynchronously.
- Modularity: ROS is highly modular, allowing you to break down complex systems into smaller, manageable components.
- Community Support: With a large and active community, ROS provides access to a wealth of resources, including libraries, packages, and tutorials.
- Platform Independence: ROS supports multiple operating systems and hardware platforms, making it versatile and adaptable to different robot configurations.
For more info, you can check the official ROS website and the following videos.
In this tutorial, we'll create a teleoperation node in ROS that allows you to control a robot in simulation using an Xbox joystick. Additionally, we'll implement functionality to save robot positions using specific buttons on the joystick.
- Understand the basics of creating a ROS node.
- Learn how to subscribe to joystick and pose messages.
- Implement teleoperation functionality with velocity control.
- Add functionality to save robot positions to a file.
We've provided a Python script in the scripts folder that serves as a template for creating a teleoperation node in ROS. This script subscribes to joystick messages and AMCL (a localization algorithm) pose messages and publishes velocity commands to control the robot's movement. Your task is to complete the code to enable teleoperation and position saving functionality.
- Understand the simulation: Before programming, launch the simulation. If you installed everything correctly, just run in a terminal:
roslaunch gazebo_simulation.launch
You should see a screen pop up with the robot inside a room similar to the Lab's stage.
You can use the following commands to check different topics and information available.
rosnode list # shows all the running nodes
rosnode info <node-name> # print info about a node
rostopic list # prints all the available topics
rostopic info <topic-name> # print info about a topic
rostopic echo <topic-name> # Listen to messages on a topic
rostopic pub <topic-name> args # Publish a message to a topic
Take your time to see all the topics available, such as those from the Joy node, the LiDAR and mobile base.
-
Understanding the Code: Before proceeding, understand the provided code structure and its purpose. Take note of the subscribers, publisher, and callback methods defined in the
Joy_Template
class. -
Completing the Teleoperation Functionality:
- In the
joy_callback()
method, implement the teleoperation logic based on the joystick input. Use the joystick axes and buttons to control the linear and angular velocity of the robot. To choose what index of button or axis to use, do a rostopic echo to the joy topic and see how tha values change when pressing buttons. - Ensure that pressing the appropriate buttons stops the robot's movement (
STOP Button
) and saves the robot's current pose (Add pose button
). - In the
amcl_callback()
method, choose the right fields of the message to store in the position variables.
- In the
-
Saving Positions:
- Implement the logic in the
joy_callback()
method to save the current robot pose when a specific button is pressed (Save ALL poses to file button
). - Use the
np.save()
function to save the list of poses to a NumPy binary file.
- Implement the logic in the
-
Testing:
- Re-start the simulation and run in another terminal the provided script after completing the necessary parts with:
rosrun homebreaker_tutorial joy_template.py
- Verify that the teleoperation functionality works as expected by controlling the robot's movement with the joystick.
- Check that pressing the designated buttons stops the robot and saves its poses correctly.
In this tutorial, you learned how to create a teleoperation node in ROS that allows you to control a robot using a joystick. You also implemented functionality to save robot positions to a file. By completing this tutorial, you've gained practical experience in ROS node creation and message handling, laying the groundwork for more complex robot applications in the future.