-
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
Erratic tf behavior due to use_sim_time parameter changed from within stage_ros #49
Comments
I agree. Guess the best option would be to not set it within EDIT: For instance, something like this:
|
I think that printing a warning should suffice. |
A warning should be ok, but I would suggest a repeating (but rate limited) warning. A single one at startup is easily missed (in the many loglines flooding a terminal) and users would still be trying to understand why TF is acting up. |
Printing a warning periodically might get bothersome if you intended to run without setting that parameter to true. |
Why would one use Stage w/o simulation time? |
I'm not familiar enough with stage to know if it can work without sim time but if it must absolutely run off of simulated time then perhaps it'd be best to terminate and print the appropriate error message instructing to set use sim time parameter. |
I think the point is that stage is a simulator, so stage itself doesn't work with sim time, but any ROS application communicating with it should probably always use sim time. The time published by stage (here). |
@gavanderhoorn thanks for clarifying, I think your suggestion above to periodically print warnings makes the most sense. |
stage_ros/src/stageros.cpp
Line 326 in c3abc19
I just took notice that the stage_ros node sets the /use_sim_time parameter to true which causes tf lookups to fail presumably due to clock time mismatches. The error message I get is as follows:
In addition to that, the robot model display in rviz reports tf failures and you see the ghost white links collapsed at the origin.
This issue is inconsistent as there are times when I launch and everything works fine but when it doesn't I restart once or twice (including the roscore) and the issue goes away. My guess is that during launch, some nodes fetch the /use_sim_time parameter before it is set by stage_ros and assign it a false value. By the time that stage_ros sets the parameter to true several nodes are already configured to operate with the real clock time.
I fixed this behavior by adding a
<param name=/use_sim_time value=true/>
entry to my launch file and this way there's no longer a race condition to set the parameter. I couldn't find any documentation that states this but I think changing a critical parameter from within a node is not the best course of action.The text was updated successfully, but these errors were encountered: