You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
run rviz using my rviz config ros2 run rviz2 rviz2 -d freezing-jazzy.rviz. The config was created with the new config button in RViz and then the manual adding of the displays, so nothing special there. I'll add it here anyways.
play a prerecorded rosbag on loop ros2 bag play -l pointcloud2_bag. The pointcloud data goes to the first display with topic /pointcloud_0. I can't attach the bag to this report, but any bag with pointcloud2 messages should reproduce this.
Turn off/on the display for /pointcloud_0. Then turn off one of the other topics( I made useless topics /any and /foo). The first time that you turn off one of these other displays the pointcloud_0 data will freeze indefinitely. To get the pointcloud to play again you need to turn on again some display. The freezing only occurs the first time that you uncheck a display box. So the first time I turn off /any freezes /pointcloud_0. If I turn on and off the /any display a bunch of times after this does nothing to the display of /pointcloud_0.
Expected behavior
I expect that toggling off the display for one topic will not affect the display of another topic.
When the ros bag is playing normally ros doctor show these as active topics:
ros2 doc TOPIC LIST initially
```console
TOPIC LIST
topic : /any
publisher count : 0
subscriber count : 1
topic : /clicked_point
publisher count : 1
subscriber count : 0
topic : /events/read_split
publisher count : 1
subscriber count : 0
topic : /foo
publisher count : 0
subscriber count : 1
topic : /goal_pose
publisher count : 1
subscriber count : 0
topic : /initialpose
publisher count : 1
subscriber count : 0
topic : /pointcloud_0
publisher count : 1
subscriber count : 1
topic : /tf
publisher count : 0
subscriber count : 1
topic : /tf_static
publisher count : 0
subscriber count : 1
```
If I turn off the display for /foo it disappears from the active topic list and there is no change to the pointcloud_0 publisher/subscriber count. This is what I expect, but then I do not understand why we do not continue to see the pointcloud_0 messages in rviz.
ros2 doc TOPIC LIST when pointcloud is frozen
```console
TOPIC LIST
topic : /any
publisher count : 0
subscriber count : 1
topic : /clicked_point
publisher count : 1
subscriber count : 0
topic : /events/read_split
publisher count : 1
subscriber count : 0
topic : /goal_pose
publisher count : 1
subscriber count : 0
topic : /initialpose
publisher count : 1
subscriber count : 0
topic : /pointcloud_0
publisher count : 1
subscriber count : 1
topic : /tf
publisher count : 0
subscriber count : 1
topic : /tf_static
publisher count : 0
subscriber count : 1
```
Actual behavior
The first time we toggle off the displays for /any or /foo the displaying of /pointcloud_0 messages to RViz stops. If I do ros2 topic echo /pointcloud_0 I can see that the publishing of /pointcloud_0 data is not affected. Turning on again one of these other displays actually makes the ros bag start playing again from the top. I first experienced this when streaming live pointcloud data. Turning off /any or /foo would stop the live streaming of data, and only turning on one of these again would continue the live streaming.
Additional information
This does not happen using ROS Humble, either in live pointcloud data scenarios or playing the same ros bag from earlier.
I ran rviz with the debug messages on. When the freezing occurs I have seen two scenarios
(1) The debug messages just stop after the subscription finalized message:
Resubscribing to a non-pointcloud_0 topic allows the pointcloud_0 data to unfreeze. These are the debug messages when I do that:
[DEBUG] [1743638041.432202608] [pluginlib.ClassLoader]: Attempting to create managed (unique) instance for class point_cloud_transport/raw_sub.
[DEBUG] [1743638041.432263922] [pluginlib.ClassLoader]: point_cloud_transport/raw_sub maps to real class type point_cloud_transport::RawSubscriber
[DEBUG] [1743638041.432307433] [pluginlib.ClassLoader]: std::unique_ptr to object of real type point_cloud_transport::RawSubscriber created.
[DEBUG] [1743638041.432339992] [rcl]: Initializing subscription for topic name '/any'
[DEBUG] [1743638041.432357385] [rcl]: Expanded and remapped topic name '/any'
[DEBUG] [1743638041.432960929] [rcl]: Subscription initialized
[INFO] [1743638041.432999714] [rviz]: Subscribing to: /any
[DEBUG] [1743638041.433138938] [rviz2]: Load pixmap at package://rviz_common/icons/ok.png
[DEBUG] [1743638041.433497959] [rviz2]: Load pixmap at package://rviz_common/icons/warning.png
[DEBUG] [1743638041.433677789] [rviz2]: Load pixmap at package://rviz_common/icons/error.png
[DEBUG] [1743638041.474275082] [rcl]: Subscription taking message
[DEBUG] [1743638041.474531964] [rcl]: Subscription take succeeded: true
[DEBUG] [1743638041.505964217] [rcl]: Subscription taking message
[DEBUG] [1743638041.506210313] [rcl]: Subscription take succeeded: true
(2) We get repeating "subscription take" failed messages about the non-pointcloud_0 display we just turned off:
[DEBUG] [1743637341.219144178] [rcl]: Subscription take succeeded: true
[DEBUG] [1743637341.282915992] [rcl]: Subscription taking message
[DEBUG] [1743637341.283134762] [rcl]: Subscription take succeeded: true
[DEBUG] [1743637341.321138034] [rcl]: Finalizing event
[DEBUG] [1743637341.321182301] [rcl]: Event finalized
[DEBUG] [1743637341.321186389] [rcl]: Finalizing event
[DEBUG] [1743637341.321189050] [rcl]: Event finalized
[DEBUG] [1743637341.321194345] [rcl]: Finalizing subscription
[DEBUG] [1743637341.321662896] [rcl]: Subscription finalized
[DEBUG] [1743637341.410368963] [rcl]: Subscription taking message
[DEBUG] [1743637341.410427568] [rcl]: Subscription take succeeded: false
[DEBUG] [1743637341.410434418] [rclcpp]: executor taking a message from topic '/foo' failed to take anything
[DEBUG] [1743637341.442677678] [rcl]: Subscription taking message
[DEBUG] [1743637341.442720443] [rcl]: Subscription take succeeded: false
[DEBUG] [1743637341.442726521] [rclcpp]: executor taking a message from topic '/foo' failed to take anything
[DEBUG] [1743637341.474258530] [rcl]: Subscription taking message
[DEBUG] [1743637341.474296742] [rcl]: Subscription take succeeded: false
[DEBUG] [1743637341.474302171] [rclcpp]: executor taking a message from topic '/foo' failed to take anything
[DEBUG] [1743637341.505949751] [rcl]: Subscription taking message
[DEBUG] [1743637341.505990354] [rcl]: Subscription take succeeded: false
[DEBUG] [1743637341.505996956] [rclcpp]: executor taking a message from topic '/foo' failed to take anything
[DEBUG] [1743637341.538223237] [rcl]: Subscription taking message
Resubscribing to /any allows the pointcloud_0 data to unfreeze, these are the debug messages when I do that:
[DEBUG] [1743637344.836934283] [pluginlib.ClassLoader]: Attempting to create managed (unique) instance for class point_cloud_transport/raw_sub.
[DEBUG] [1743637344.836967728] [pluginlib.ClassLoader]: point_cloud_transport/raw_sub maps to real class type point_cloud_transport::RawSubscriber
[DEBUG] [1743637344.836999869] [pluginlib.ClassLoader]: std::unique_ptr to object of real type point_cloud_transport::RawSubscriber created.
[DEBUG] [1743637344.837030380] [rcl]: Initializing subscription for topic name '/any'
[DEBUG] [1743637344.837047348] [rcl]: Expanded and remapped topic name '/any'
[DEBUG] [1743637344.837768407] [rcl]: Subscription initialized
[INFO] [1743637344.837823991] [rviz]: Subscribing to: /any
[DEBUG] [1743637344.866560252] [rcl]: Subscription taking message
[DEBUG] [1743637344.866720149] [rcl]: Subscription take succeeded: false
[DEBUG] [1743637344.866729790] [rclcpp]: executor taking a message from topic '/foo' failed to take anything
[DEBUG] [1743637344.898178119] [rcl]: Subscription taking message
[DEBUG] [1743637344.898444160] [rcl]: Subscription take succeeded: true
[DEBUG] [1743637344.930734151] [rcl]: Subscription taking message
The text was updated successfully, but these errors were encountered:
Operating System:
Linux 6.11.0-21-generic #21~24.04.1-Ubuntu SMP PREEMPT_DYNAMIC Mon Feb 24 16:52:15 UTC 2 x86_64 x86_64 x86_64 GNU/Linux
ROS version or commit hash:
jazzy
RMW implementation (if applicable):
rmw_fastrtps_cpp
RMW Configuration (if applicable):
No response
Client library (if applicable):
No response
'ros2 doctor --report' output
ros2 doc --report
Steps to reproduce issue
run rviz using my rviz config
ros2 run rviz2 rviz2 -d freezing-jazzy.rviz
. The config was created with the new config button in RViz and then the manual adding of the displays, so nothing special there. I'll add it here anyways.play a prerecorded rosbag on loop
ros2 bag play -l pointcloud2_bag
. The pointcloud data goes to the first display with topic /pointcloud_0. I can't attach the bag to this report, but any bag with pointcloud2 messages should reproduce this.Turn off/on the display for /pointcloud_0. Then turn off one of the other topics( I made useless topics /any and /foo). The first time that you turn off one of these other displays the pointcloud_0 data will freeze indefinitely. To get the pointcloud to play again you need to turn on again some display. The freezing only occurs the first time that you uncheck a display box. So the first time I turn off /any freezes /pointcloud_0. If I turn on and off the /any display a bunch of times after this does nothing to the display of /pointcloud_0.
Expected behavior
I expect that toggling off the display for one topic will not affect the display of another topic.
When the ros bag is playing normally ros doctor show these as active topics:
ros2 doc TOPIC LIST initially
```console TOPIC LIST topic : /any publisher count : 0 subscriber count : 1 topic : /clicked_point publisher count : 1 subscriber count : 0 topic : /events/read_split publisher count : 1 subscriber count : 0 topic : /foo publisher count : 0 subscriber count : 1 topic : /goal_pose publisher count : 1 subscriber count : 0 topic : /initialpose publisher count : 1 subscriber count : 0 topic : /pointcloud_0 publisher count : 1 subscriber count : 1 topic : /tf publisher count : 0 subscriber count : 1 topic : /tf_static publisher count : 0 subscriber count : 1 ```ros2 doc TOPIC LIST when pointcloud is frozen
```console TOPIC LIST topic : /any publisher count : 0 subscriber count : 1 topic : /clicked_point publisher count : 1 subscriber count : 0 topic : /events/read_split publisher count : 1 subscriber count : 0 topic : /goal_pose publisher count : 1 subscriber count : 0 topic : /initialpose publisher count : 1 subscriber count : 0 topic : /pointcloud_0 publisher count : 1 subscriber count : 1 topic : /tf publisher count : 0 subscriber count : 1 topic : /tf_static publisher count : 0 subscriber count : 1 ```Actual behavior
The first time we toggle off the displays for /any or /foo the displaying of /pointcloud_0 messages to RViz stops. If I do
ros2 topic echo /pointcloud_0
I can see that the publishing of /pointcloud_0 data is not affected. Turning on again one of these other displays actually makes the ros bag start playing again from the top. I first experienced this when streaming live pointcloud data. Turning off /any or /foo would stop the live streaming of data, and only turning on one of these again would continue the live streaming.Additional information
This does not happen using ROS Humble, either in live pointcloud data scenarios or playing the same ros bag from earlier.
I ran rviz with the debug messages on. When the freezing occurs I have seen two scenarios
(1) The debug messages just stop after the subscription finalized message:
Resubscribing to a non-pointcloud_0 topic allows the pointcloud_0 data to unfreeze. These are the debug messages when I do that:
(2) We get repeating "subscription take" failed messages about the non-pointcloud_0 display we just turned off:
Resubscribing to /any allows the pointcloud_0 data to unfreeze, these are the debug messages when I do that:
The text was updated successfully, but these errors were encountered: