-
Notifications
You must be signed in to change notification settings - Fork 123
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
Subscribing with Theora compression reduces publish rate #163
Comments
I was able to work around this issue by running the following command in another terminal.
For example if I have a topic called It seems that the reason the publish rate is dropping when someone subscribes to the original theora topic from the image_transport is bad QoS settings. Although I had not modified my QoS settings for either case but something seems to be overriding them for the original scenario. By "original scenario" I mean that I have a publisher that is an |
Hi @s-m-asjad, image_transport compression happened in publisher's node since ROS1. Looking at Humble code
Unless ROS camera driver (sensor, your source) is written taking above into account (for example by decoupling internal driver logic into thread) the total time ROS driver has will be limited by driver internal handling and compression time. A lot of ROS drivers are written not taking above into account.
As you have noticed you may decouple compression time from driver internals using republish. In such scenario both driver/source and compression should have full frame time available for own processing. I don't know about QoS settings but above may be one of the causes of your problems. Also, I am not sure but it is possible that theora may emit multiple packets (ROS messages) per single image. You would need to double check. In case message delivery is not guaranteed loosing one of those messages might prevent decoding image. In particular loosing one of keyframe sub-messages might prevent receiving images until next keyframe. |
Hi @bmegli Thankyou for your that great insight. It might as well be the first issue you mentioned of not having a decent driver. My driver followed the same basic skeleton as this for the initial tests but I do plan to eventually isolate driver logic into its own separate thread. I shall look into this and hopefully it indeed pops up as the root of all evil. I am certain that the issue is not caused by
(I could be mistaken though, please feel free to correct me) because I tried doing |
Yes, your understanding is correct:
Even if driver doesn't take into account that compression may consume part of its processing time, it's easily fixable with republish. Also, you may just measure (even with simple timer logic and debug output from node):
|
Core of the issue might be this ros2/ros2#1434 Does the theora compression thread on the publisher use close to 100% of one of your CPU cores? |
This has been tested on both, a local and remote system setting, with ROS2 Humble.
Occasionally, the publisher's frequency of publishing images will drop from 30FPS to ~15FPS and lower depending on the size of image. Theora seems to stand strong when streaming HD images at 30FPS but going FHD will occasionally drop the publish rate to 15 FPS (it will stay at the lower FPS until the subscriber is killed).
There have been instances where streaming at 2K was successful without a drop in the publisher's rate of publishing although we lost frames at the subscriber. This however, does not seem persistent as other times (as mentioned previously) subscribing to the theora topic would reduce the publish rate of the publisher too.
If the setup is tested in a remote setting, subscribing to the default compressed topic, we see a large amount of data (usually in MB/s) going out towards the local system which is expected behavior. In the case of theora, when the aforementioned issue is not encountered, data usually in MB/s is seen being streamed (also expected behavior). However, when subscribing to the theora topic reduces the FPS of the publisher, we observe significantly reduced data being streamed, usually under in 200s of kB/s. This implies that the network has higher bandwidth for streaming, however, theora seems to not be using it and hence introducing latency.
We observed the data streamed out using
ifstat -i
and the topic publish rate viaros2 topic hz
The text was updated successfully, but these errors were encountered: