-
Notifications
You must be signed in to change notification settings - Fork 434
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
Feature Request: Dynamic Type Handling for Generic Subscriptions #2568
Comments
I found this simillar unanswered question: https://answers.ros.org/question/405796/deserialize-message-with-topic-name-ros2/ |
@Barry-Xu-2018 do you have any thoughts? |
I think there are two scenarios.
In the first scenario, you should be able to easily cast the pointer to the message type. In the second scenario, you can use type support to parse each type in the message one by one. |
Thanks @Barry-Xu-2018 for your answer. Mine is the second scenario, I'd be grateful if you can provide an example. I would try it out and give feedback in a couple of hours |
It would definitely be useful to a handful of people given that it's been asked a couple of times already here and there Also the reason why we would need a tutorial for this is because it's (imo) a reasonable thing for high-level users of ROS to want to do but the way to do it seems pretty low-level (with type support and other things I've never heard of with 5 years of experience with ROS). So I'm wondering if it would make sense to expose this functionality on a higher-level? Some function in client libraries? |
I stumbled upon https://github.com/facontidavide/rosx_introspection and was able to make a prototype! Here is the pseudo-code: #include "rosx_introspection/ros_parser.hpp"
#include "rosx_introspection/ros_utils/ros2_helpers.hpp"
using namespace RosMsgParser;
ParsersCollection<ROS2_Deserializer> parser_;
void print_fields(const std::string& topic_name, const std::string& topic_type, std::shared_ptr<const rclcpp::SerializedMessage> serialized_message) {
parser_.registerParser(topic_name, ROSType(topic_type),
GetMessageDefinition(topic_type));
std::vector<uint8_t> buffer(serialized_message->get_rcl_serialized_message().buffer_length);
memcpy(buffer.data(), serialized_message->get_rcl_serialized_message().buffer, serialized_message->get_rcl_serialized_message().buffer_length);
const FlatMessage* flat_container = parser_.deserialize(topic_name, Span<uint8_t>(buffer));
for (auto& it : flat_container->value)
{
std::cout << it.first << " >> " << it.second.convert<double>() << std::endl;
}
for (auto& it : flat_container->name)
{
std::cout << it.first << " >>>" << it.second << std::endl;
}
} @facontidavide thanks for that project. As there is no real guide, I got inspired from the tests mostly, am I using your library correctly? Any recommendations? @Barry-Xu-2018 @fujitatomoya maybe this could be a good starting point to implement something similar in rclcpp? |
Just found #2260 which is also similar |
Apologies for the delayed reply. I will prepare a simple example for you. I'll look into https://github.com/facontidavide/rosx_introspection. |
This is a simple sample (The code is a bit ugly. I haven't had time to check out the implementation of rosx_introspection yet.). It tries to get items of sensor_msgs::msg::Temperature based on generic subscription. |
Would using rosx_introspection meet your requirements ? If there are no further questions, can I close this issue? |
Hi @Barry-Xu-2018, I didn't go beyond an initial prototype yet using rosx_introspection but that seemed to work.
I still think this could make sense to implement in rclcpp. If you disagree, then we can close the issue for now and I would report back if more than your example or rosx_introspection is needed. Thanks for your support |
Based on my thoughts, this isn't a general requirement, so it's not quite suitable to include in rclcpp. Of course, we can listen to others' opinions as well. |
Cross-linking another repo I found related to this issue: https://github.com/LOEWE-emergenCITY/ros_babel_fish FYI @StefanFabian |
Thanks for the mention @tonynajjar One noteworthy difference to
In my biased view, I think |
Feature request
Feature description
I am developing an application where I need to subscribe to topics with unknown message types (similar to rosbag2). In the subscription callback, I need access to the deserialized message and its fields without knowing the type in advance.
There is a related example here, but it requires specifying the type (
T2
) beforehand. I am looking for a way to use only the topictype
as a string to dynamically obtain the message class.Using snippets here and there from rclcpp I put together this incomplete example:
The issue is that deserialized_msg is a null pointer ('void *'), and I am unsure how to proceed from here.
If there is currently no way to achieve this, please consider this a feature request. I am open to contributing with some guidance on the implementation. Thanks!
Related:
https://answers.ros.org/question/405796/deserialize-message-with-topic-name-ros2/
#2260
ros2/ros2#1374
https://github.com/facontidavide/rosx_introspection
The text was updated successfully, but these errors were encountered: