diff --git a/assets/middleware/ros2/px4_ros2_interface_lib/translation_node.drawio b/assets/middleware/ros2/px4_ros2_interface_lib/translation_node.drawio new file mode 100644 index 000000000000..68030a1401e5 --- /dev/null +++ b/assets/middleware/ros2/px4_ros2_interface_lib/translation_node.drawio @@ -0,0 +1,172 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/assets/middleware/ros2/px4_ros2_interface_lib/translation_node.svg b/assets/middleware/ros2/px4_ros2_interface_lib/translation_node.svg new file mode 100644 index 000000000000..674988271938 --- /dev/null +++ b/assets/middleware/ros2/px4_ros2_interface_lib/translation_node.svg @@ -0,0 +1,4 @@ + + + +
 PX4
 Fast-DDS
uORB topic
uXRCE-DDS
client
uORB topic
uORB topic
uXRCE-DDS
agent
ROS 2
Message
Translation
Node
ROS 2
Application Node
ROS 2
Application Node
 Fast-DDS
uXRCE-DDS
agent
ROS 2
Message
Translation
Node
ROS 2
Application Node
msg: VehicleAttitudeV3
topic: /fmu/out/vehicle_attitude_v3
ROS 2
Application Node
msg: VehicleCommandV2
topic: /fmu/out/vehicle_command_v2
msg: VehicleCommandV3
topic: /fmu/out/vehicle_command_v3
msg: VehicleAttitudeV5
topic: /fmu/out/vehicle_attitude_v5
msg: VehicleAttitudeV4
topic: /fmu/out/vehicle_attitude_v4
msg: VehicleCommandV3
topic: /fmu/out/vehicle_command_v3
\ No newline at end of file diff --git a/en/middleware/uorb.md b/en/middleware/uorb.md index 8321e075cfe5..1a5b8470309e 100644 --- a/en/middleware/uorb.md +++ b/en/middleware/uorb.md @@ -145,6 +145,8 @@ The full API is documented in [platforms/common/uORB/uORBManager.hpp](https://gi +Message versioning has been in introduced in PX4 v1.16 to make it easier to maintain compatibility between PX4 and ROS 2 versions. + Message versioning was introduced to address the challenges of maintaining compatibility across systems where different versions of message definitions may be in use, such as between PX4 and external systems like ROS 2 applications. This versioning mechanism supports the [ROS 2 Message Translation Node](../ros2/px4_ros2_msg_translation_node.md), which enables seamless communication between PX4 and ROS 2 applications; when different versions of message definitions are in use, the ROS 2 translation node ensures that messages can be converted and exchanged correctly. diff --git a/en/ros2/px4_ros2_msg_translation_node.md b/en/ros2/px4_ros2_msg_translation_node.md index cdb6e0dce4bf..5ac4c0a8872e 100644 --- a/en/ros2/px4_ros2_msg_translation_node.md +++ b/en/ros2/px4_ros2_msg_translation_node.md @@ -4,13 +4,21 @@ The message translation node allows ROS 2 applications that were compiled against different versions of the PX4 messages to interwork with newer versions of PX4, and vice versa, without having to change either the application or the PX4 side. -Specifically for this to work, topic publication/subscription/service names contain a message version in the form of `_v`. +## Overview -Specifically, the translation node knows about all message versions previously defined by PX4, and dynamically monitors the publications, subscriptions and services, translating them into the current versions expected by the application and PX4 as needed. +The translation node has access to all message versions previously defined by PX4. It dynamically observes the DDS data space, monitoring the publications, subscriptions and services originating from either PX4 via the [uXRCE-DDS Bridge](../middleware/uxrce_dds.md), or ROS2 applications. When necessary, it converts messages to the current versions expected by both applications and PX4, ensuring compatibility. + +![Overview ROS 2 Message Translation Node](../../assets/middleware/ros2/px4_ros2_interface_lib/translation_node.svg) + + + +To support the coexistance of different versions of the same messages within the ROS 2 domain, the ROS 2 topic names for publications, subscriptions, and services include their respective message version as a suffix. This naming convention takes the form `_v`, as shown in the diagram above. ## Installation -1. Create a ROS 2 workspace in which to build the message translation node and its dependencies. +The following steps describe how to install and run the translation node on your machine. + +1. Create a ROS 2 workspace in which to build the message translation node and its dependencies: ```sh mkdir -p /path/to/ros_ws/src @@ -42,6 +50,61 @@ Specifically, the translation node knows about all message versions previously d [INFO] [1734525720.729594413] [translation_node]: Registered services and versions: ``` +With the translation node running, any ROS 2 application designed to communicate with PX4 can do so, as long as it uses message versions recognized by the node. + +::: note +After making a modification in PX4 to the message defintions and/or translation node code, you will need to rerun the steps above from point 2. to update your ROS workspace accordingly. +::: + +## Usage in ROS + +While developing a ROS 2 application, it is not necessary to know the specific version of message used to communicate with PX4. +The message version can be added generically to a topic name like this: + +```c++ +topic_name + "_v" + std::to_string(T::MESSAGE_VERSION) +``` + +where `T` is the message type, e.g. `px4_msgs::msg::VehicleAttitude`. + +For example, the following implements a minimal subscriber and publisher node that uses two versioned PX4 messages and topics: + +```c++ +#include +#include +#include +#include + +class MinimalPubSub : public rclcpp::Node { + public: + MinimalPubSub() : Node("minimal_pub_sub") { + // Define the appropriate topic to pub/sub to, based on the + // message version contained in the message defintion + const std::string sub_topic = "/fmu/out/vehicle_attitude_v" + std::to_string(px4_msgs::msg::VehicleAttitude::MESSAGE_VERSION); + const std::string pub_topic = "/fmu/in/vehicle_command_v" + std::to_string(px4_msgs::msg::VehicleCommand::MESSAGE_VERSION); + + _subscription = this->create_subscription( + sub_topic, 10, + std::bind(&MinimalPubSub::attitude_callback, this, std::placeholders::_1)); + _publisher = this->create_publisher(pub_topic, 10); + } + + private: + void attitude_callback(const px4_msgs::msg::VehicleAttitude::SharedPtr msg) { + RCLCPP_INFO(this->get_logger(), "Received attitude message."); + } + + rclcpp::Publisher::SharedPtr _publisher; + rclcpp::Subscription::SharedPtr _subscription; +}; +``` + +On the PX4 side, the DDS client automatically adds the version suffix if a message definition contains the field `uint32 MESSAGE_VERSION = x`. + +::: info +Version 0 of a topic means that no `_v` suffix should be added. +::: + ## Updating a Message When changing a message, a new version needs to be added. @@ -74,21 +137,6 @@ If a nested message definition changes, all messages including that message also This is primarily important for services. ::: -## Usage in ROS - -The message version can be added generically to a topic like this: - -```c++ -topic_name + "_v" + std::to_string(T::MESSAGE_VERSION) -``` - -Where `T` is the message type, e.g. `px4_msgs::msg::VehicleAttitude`. - -The DDS client in PX4 automatically adds the version suffix if a message contains the field `uint32 MESSAGE_VERSION = x`. - -::: info -Version 0 of a topic means that no `_v` suffix should be added. -::: ## Implementation Details diff --git a/en/ros2/user_guide.md b/en/ros2/user_guide.md index 8e676fef6943..b9bc8dfc7c98 100644 --- a/en/ros2/user_guide.md +++ b/en/ros2/user_guide.md @@ -234,7 +234,7 @@ The micro XRCE-DDS agent terminal should also start to show output, as equivalen ### Build ROS 2 Workspace -This section shows how create a ROS 2 workspace hosted in your home directory (modify the commands as needed to put the source code elsewhere). +This section shows how to create a ROS 2 workspace hosted in your home directory (modify the commands as needed to put the source code elsewhere). The [px4_ros_com](https://github.com/PX4/px4_ros_com) and [px4_msgs](https://github.com/PX4/px4_msgs) packages are cloned to a workspace folder, and then the `colcon` tool is used to build the workspace. The example is run using `ros2 launch`.