Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Publishing protobuf Messages in ros #35

Open
Oszimilian opened this issue Mar 28, 2024 · 1 comment
Open

Publishing protobuf Messages in ros #35

Oszimilian opened this issue Mar 28, 2024 · 1 comment

Comments

@Oszimilian
Copy link

Hello,
I am not sure if I have understood this library correctly.
I have a Ros node that receives protobuf messages. These messages contain a lot of deserialized messages. I want to put these messages into ros space. This means that each proto message needs to be converted into a ros message.
Is this the use case for this library?

@FlorianReimold
Copy link
Member

FlorianReimold commented Mar 28, 2024

The goal of this library is serialize ROS messages with protobuf.

In ROS2, the ROS library / API itself doesn't define a data transport or a data serialization (even though it ships with a default one). The RMW (Ros Middleware Layer) needs to serialize the Ros Messages to a format that they can transmit. This is done via rosidl_typesupport packages. There are many of those packages. This one uses protobuf for serialization. It was initially developed for the rmw_ecal. eCAL doesn't really care about the data serialization, as it only transports binary blobs. However, as eCAL and Protobuf work well together, we developed the rosidl_typesupport_protobuf, which can serialize the ros messages to a binary buffer via protobuf.

If you have a serialized protobuf message in an std::string, etc. , you don't need this typesupport. You rather need to obtain the original .proto file for that message and use protoc to generate the cpp / python etc. class structure for that that message. You can then call DeserializeFromString to parse your binary blob and make if fill your class.
You can now copy the data to your ROS messages. Usually it's faster to do that by hand (maybe some AI tools like ChatGPT can help here, too). However if you really have a lot of messages or the message format changes often, you can check the code in this repo, as the typesupport also generated some glue code converting from protobuf classes to the ROS message API. You could use it as a template to do some autocode generation.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants