ROS Resources: Documentation | Support | Discussion Forum | Index | Service Status | ros @ Robotics Stack Exchange
Ask Your Question
0

Tf transform failure

asked 2021-10-08 08:19:20 -0600

Roshan gravatar image

updated 2021-10-08 08:39:30 -0600

Hello, I'm writing rosrun tf tf_echo fiducial_0 tb3_1/camera_rgb_optical_frame in the command line, and then I get this out:

Failure at 4640.886000000
Exception thrown:"fiducial_0" passed to lookupTransform argument target_frame does not exist. 
The current list of frames is:
Frame tb3_0/base_link exists with parent tb3_0/base_footprint.
Frame tb3_0/camera_link exists with parent tb3_0/base_link.
Frame tb3_0/camera_rgb_frame exists with parent tb3_0/camera_link.
Frame tb3_0/camera_rgb_optical_frame exists with parent tb3_0/camera_rgb_frame.
Frame tb3_0/caster_back_left_link exists with parent tb3_0/base_link.
Frame tb3_0/caster_back_right_link exists with parent tb3_0/base_link.
Frame tb3_0/imu_link exists with parent tb3_0/base_link.
Frame tb3_0/base_scan exists with parent tb3_0/base_link.
Frame tb3_1/base_link exists with parent tb3_1/base_footprint.
Frame tb3_1/base_footprint exists with parent tb3_1/odom.
Frame tb3_1/camera_link exists with parent tb3_1/base_link.
Frame tb3_1/camera_rgb_frame exists with parent tb3_1/camera_link.
Frame tb3_1/camera_rgb_optical_frame exists with parent tb3_1/camera_rgb_frame.
Frame tb3_1/caster_back_left_link exists with parent tb3_1/base_link.
Frame tb3_1/caster_back_right_link exists with parent tb3_1/base_link.
Frame tb3_1/imu_link exists with parent tb3_1/base_link.
Frame tb3_1/base_scan exists with parent tb3_1/base_link.
Frame tb3_1/wheel_left_link exists with parent tb3_1/base_link.
Frame tb3_1/wheel_right_link exists with parent tb3_1/base_link.

Failure at 4640.886000000
Exception thrown:"fiducial_0" passed to lookupTransform argument target_frame does not exist. 
The current list of frames is:
Frame tb3_0/base_link exists with parent tb3_0/base_footprint.
Frame tb3_0/camera_link exists with parent tb3_0/base_link.
Frame tb3_0/camera_rgb_frame exists with parent tb3_0/camera_link.
Frame tb3_0/camera_rgb_optical_frame exists with parent tb3_0/camera_rgb_frame.
Frame tb3_0/caster_back_left_link exists with parent tb3_0/base_link.
Frame tb3_0/caster_back_right_link exists with parent tb3_0/base_link.
Frame tb3_0/imu_link exists with parent tb3_0/base_link.
Frame tb3_0/base_scan exists with parent tb3_0/base_link.
Frame tb3_1/base_link exists with parent tb3_1/base_footprint.
Frame tb3_1/base_footprint exists with parent tb3_1/odom.
Frame tb3_1/camera_link exists with parent tb3_1/base_link.
Frame tb3_1/camera_rgb_frame exists with parent tb3_1/camera_link.
Frame tb3_1/camera_rgb_optical_frame exists with parent tb3_1/camera_rgb_frame.
Frame tb3_1/caster_back_left_link exists with parent tb3_1/base_link.
Frame tb3_1/caster_back_right_link exists with parent tb3_1/base_link.
Frame tb3_1/imu_link exists with parent tb3_1/base_link.
Frame tb3_1/base_scan exists with parent tb3_1/base_link.
Frame tb3_1/wheel_left_link exists with parent tb3_1/base_link.
Frame tb3_1/wheel_right_link exists with parent tb3_1/base_link.

At time 4641.670
- Translation: [-0.133, -0.153, 0.715]
- Rotation: in Quaternion [0.994, -0.005, 0.082, -0.066]
            in RPY (radian) [-3.007, -0.163, -0.020]
            in RPY (degree) [-172.305, -9.325, -1.153]
At time 4642.704
- Translation: [-0.133, -0.153, 0.715]
- Rotation: in Quaternion [0.994, -0.005, 0.082, -0.066]
            in RPY (radian) [-3.007, -0.163, -0.020]
            in RPY (degree) [-172.305, -9.325, -1.153]
At time 4643.656
- Translation: [-0.133, -0.153, 0.715]
- Rotation: in Quaternion [0.994, -0.005, 0.082, -0.066]
            in RPY (radian) [-3.007, -0.163, -0.020]
            in RPY (degree) [-172.304, -9.328, -1.154]
At time 4644.586
- Translation: [-0.021, 0.142, 0.721]
- Rotation: in Quaternion ...
(more)
edit retag flag offensive close merge delete

Comments

The other transforms are static and published on startup, but perhaps it takes some time for aruco_detect to find and publish the transform. Does that not fit with your experience/expectation?

tryan gravatar image tryan  ( 2021-10-08 11:12:58 -0600 )edit

I don't have much experience with this, so I can't really tell. But that does make sense, so thank you. That might be why it doesn't show up when I rostopic echo /tf_static too

Roshan gravatar image Roshan  ( 2021-10-08 12:35:41 -0600 )edit

Happy to help. And yes, I would only expect to see fixed transforms (e.g., base_link -> imu_link) on /tf_static. I will post an answer. If you're satisfied that the problem is resolved, please, mark it as accepted, but feel free to ask for further clarification.

tryan gravatar image tryan  ( 2021-10-08 14:18:33 -0600 )edit

It seems pretty clear now, so static transforms are the transforms that are there from the start, but because the transforms to fiducial isn't static is because it is only there if a marker is detected. One other question I have is about the sudden changes in the translation of the transform, that seems a little weird especially since the robots are standing still

Roshan gravatar image Roshan  ( 2021-10-08 14:26:43 -0600 )edit

I can't speak to the accuracy of the algorithm (maybe +/- 15 cm is expected?), but I suspect it depends on several details, e.g., marker arrangement/number/size, camera calibration/resolution, simulation vs. real robot, etc. I would ask the package maintainers, but you could also try posting a separate question concerning accuracy. You may get an answer here, but if you find a forum more specific to ArUco markers, you may have better luck. Sorry, I can't help more with that one.

tryan gravatar image tryan  ( 2021-10-08 15:28:44 -0600 )edit

1 Answer

Sort by ยป oldest newest most voted
1

answered 2021-10-08 14:33:25 -0600

tryan gravatar image

I'm not very familiar with the aruco_detect package, but because the transform is between an optical frame and a fiducial frame, I assume that it's a transform the node figures out at runtime. As such, there may be a delay before it first publishes the resulting transform, while the node does the necessary calculations. As soon as the transform is available in the tf tree, you should be able to echo it without error.

The reason the other transforms are all available immediately is that they are predefined static transforms and don't require any calculations. The statistics for such transforms look like this:

Average rate: 10000.0
Buffer length: 0.0
Most recent transform: 0.0
Oldest transform: 0.0

edit flag offensive delete link more

Comments

Just a question after I checked through the TF tree again. Shouldn't the transforms between odom and base_footprint also have the same problem?

Edit: After testing, it does actually happen for them. Another weird thing is that after trying to run the tf echo several times, it only fails sometimes

Roshan gravatar image Roshan  ( 2021-10-08 17:18:04 -0600 )edit
1

Good catch. Yes, any transform that isn't static may run into timing issues. The tf2 tutorial on listeners may provide more insight (I recommend all of the tf2 documentation actually), but basically, every listener must fill its internal buffer with transforms. If it tries to query a particular transform before it's in the buffer, the lookup will fail. Depending on the exact timing of when the listener initializes then starts querying vs. when the transform is next published, the transform may not be in the buffer for some amount of time, causing failed lookups at first.

tryan gravatar image tryan  ( 2021-10-08 19:32:37 -0600 )edit

Question Tools

2 followers

Stats

Asked: 2021-10-08 08:19:20 -0600

Seen: 697 times

Last updated: Oct 08 '21