-
Notifications
You must be signed in to change notification settings - Fork 429
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
Automatic/adaptive subscription QoS #1868
Comments
As another pointer, there's another implementation of this in Here are other threads discussing this feature:
I think it makes sense to have two functions in @emersonknapp I think these functions could easily satisfy your second and third behavioral considerations: get the highest possible QoS and account for multiple entities with different QoS. However, doing something like re-adapting to new pub/subs on the graph sounds difficult. We considered re-adapting QoS during runtime for the |
I think we do need to have new RMW interface to reset the QoS for publisher and subscriber at runtime to achieve this |
You're opening a can of worms here ... the very short answer is that in DDS it is impossible to make a data reader that will "reliably" get data from all writers for the same topic without getting duplicates:
Furthermore, some of the QoS settings that do this problematic request-offered (RxO) matching and that are supported by ROS 2 cannot be changed: reliability, durability and liveliness are fixed at creation time of a reader/writer. If you really want to go ahead with this, I'd suggest recreating the publisher/subscription, make sure that the new one is discovered before deleting the old one and deal with any double arrivals separately. The only alternative would be DDS spec changes or vendor-specific extensions to implement different matching rules, which could be done in such a way that there'd be no need to adapt anything. Sadly, vendor-specific will get messy if interoperability is desired and the spec changes more slowly than a glacier melts in an ice age ... |
@eboasson appreciate for your quick and informative comments.
i see. at least i do not have any other ways to achieve this. and it seems like it is not worth the effort... |
@jacobperron (and others) I think it makes sense to provide the utilities to adapt a subscription to a known set of publisher qos profiles. We could skip re-adapting to newly discovered publishers, in the requirements for this particular ticket - and revisit that as its own feature, if desired, later. |
With the assumption that publishers exist at subscription creation time and not adapt to new publishers, listing here a couple of approaches to this. My thought was to add the detection logic in Approach 1
Pros:
Cons:
Approach 2
Pros:
Cons:
|
After some iteration, I've proposed adding new policy enum values at the RMW layer for selecting the 'best available' policy (ie. the policy that will match the most endpoints while maintaining the highest level of service). Feedback is welcome: ros2/rmw#320 This delegates to the middleware for how to implement the matching logic. For DDS implementations, we provide a common implementation that will query discovered endpoints at the time of creating a subscription/publisher and use that information to adapt the QoS policies: ros2/rmw_dds_common#60 |
Feature request
Feature description
Provide the ability for a subscription to automatically choose a QoS based on detected QoS of publishers in the graph. Most times for the business logic of robot applications, we want to explicitly specify QoS policies to clearly lay out communication behavior requirements.
However, some tooling and infrastructure by design does not care about the exact behavior and just wants to match with publishers no matter what, at as high a level of fidelity/service as possible. Three use cases come to mind up front:
ros2 topic echo
in my view should always start printing messages, if there is a publisher providing them, regardless of QoS mismatchrelay
,throttle
andmux
generally want to receive messages from publishers and imitate those publisher's behaviors, with modificationsThis feature API might be:
AdaptiveQoSSubscription
that provides this behaviorSubscriptionOptions
value that turns this onAdaptiveSubscriptionQoSProfile
that acts as a flag to enable the behaviorBehavior considerations:
Implementation considerations
Will need this in both
rclpy
andrclcpp
. Python is necessary to expose to ros2cli and some topic_tools. Given that, maybe this feature belongs inrcl
or maybe even in some RMW utility package.There are two current implementations that I know of for this feature, in
rosbag2
and intopic_tools
. Using those as a starting point for a "core" implementation makes sense to me.See https://github.com/ros2/rosbag2/blob/master/rosbag2_transport/src/rosbag2_transport/qos.cpp for rosbag2 logic - those tools used around https://github.com/ros2/rosbag2/blob/master/rosbag2_transport/src/rosbag2_transport/recorder.cpp#L238
The text was updated successfully, but these errors were encountered: