-
Notifications
You must be signed in to change notification settings - Fork 265
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
docs: Add note about long running callbacks #218
base: master
Are you sure you want to change the base?
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
First, I'll still prefer someone spending more time to find more correct solution for this issue, without "dirtying" the user code.
Second, I see no reason for using Queue
here. Event
is totally enough. This works perfectly:
import rospy
from sensor_msgs.msg import Image
import threading
rospy.init_node('computer_vision_sample')
e = threading.Event()
def image_callback(data):
global latest_img
latest_img = data
e.set()
image_sub = rospy.Subscriber('main_camera/image_raw', Image, image_callback, queue_size=1, buff_size=999999)
while not rospy.is_shutdown():
e.wait()
e.clear()
print(latest_img.header.stamp.to_sec(), rospy.get_rostime().to_sec())
Finally, I don't like keeping several ways of wrapping the user code for processing the image. This confuses user. We should keep only one, "correct" way (the "fixed" version for now).
Okay, I believe I see your point. Using a Regarding your example: it does look simplier, but I still have some issues with it:
As for your last point, well, the "best" way would be to do something similar to how OpenCV does that. Most people doing CV-related stuff have already learned some patterns, and this is where your example comes close: having a "main loop" with all image processing is nice (although that would probably lead to mixing image processing code and flight code, which I believe should be discouraged). Actually, your last point brings up our docs' overall deficiency: we don't have a preferred way of writing complex flight code. |
К слову: у нас больше проблем с производительностью обработки картинок вызывал не threading, а то, что на питоне не работает image_transport (http://wiki.ros.org/image_transport#Python_Usage), что вызывает задержку до 0.1 сек при прокачке кадра через рос топик. |
I investigated the issue a little bit more. The "problem" is actually in this code: https://github.com/ros/ros_comm/blob/noetic-devel/clients/rospy/src/rospy/impl/tcpros_base.py#L795. The client code does correct thing cutting the latest messages from the buffer (https://github.com/ros/ros_comm/blob/noetic-devel/clients/rospy/src/rospy/msg.py#L225) to process. But since reading the socket and calling callbacks perform in the same thread (at least for one By the way, Linux TCP buffer size can be inspected in |
@copterspace, сомневаюсь, что дело именно в большом времени передачи изображения, а не в той проблеме, которую мы обсуждаем. Когда я получаю изображения с камеры с помощью воркэраунда выше, то измеряемое время передачи на порядки меньше, чем 0.1с. |
Actually, I would call that a bug, which can be simply avoided using separate threads for reading the socket and invoking the callbacks. It deserves issuing and fixing in |
Opened an issue in |
Clover package Python library added.
Having a long running callback will result in messages being handled with a significant delay, regardless of the
queue_size
option. This is especially noticeable for image processing. We should at the very least document that.This P/R adds a note about using separate threads for image processing, as well as some minimal sample code.