{{{#!wiki tip Using ROS 2? Check out the [[https://docs.ros.org/en/rolling/Tutorials/Intermediate/Tf2/Tf2-Main.html|ROS 2 tf2 tutorials]]. }}} ## page was renamed from tf22/Tutorials/Time travel in tf22 (C++) #################################### ##FILL ME IN #################################### ## for a custom note with links: ## note = This tutorial assumes you have completed the tf2 and time [[tf2/Tutorials/tf2 and time (Python)|(Python)]] [[tf2/Tutorials/tf2 and time (C++)|(C++)]] tutorials ## for the canned note of "This tutorial assumes that you have completed the previous tutorials:" just add the links ## note.0= ## descriptive title for the tutorial ## title = Time travel with tf2 (C++) ## multi-line description to be displayed in search ## description = This tutorial teaches you about advanced time travel features of tf2 ## the next tutorial description (optional) ## next = ## links to next tutorial (optional) ## next.0.link= ## next.1.link= ## what level user is this tutorial for ## level= AdvancedCategory ## keywords = #################################### <<IncludeCSTemplate(TutorialCSHeaderTemplate)>> <<TableOfContents(4)>> In the [[tf2/Tutorials/tf2 and time (C++)|previous tutorial]] we discussed the basic concept of tf2 and time. This tutorial will take this one step further, and expose one of the most powerful tf2 tricks. == Time travel == So let's go back to where we ended in the [[tf2/Tutorials/tf2 and time (C++)|previous tutorial]]. Go to your package for the tutorial: {{{ $ roscd learning_tf2 }}} and open the file '''`src/turtle_tf2_listener.cpp`'''. Take a look at lines 25-30: {{{ try{ ros::Time now = ros::Time::now(); transformStamped= tfBuffer.lookupTransform("turtle2", "turtle1", now); }}} Now, instead of making the second turtle go to where the first turtle is '''now''', make the second turtle go to where the first turtle was '''5 seconds ago''': {{{ try{ ros::Time past = ros::Time::now() - ros::Duration(5.0); transformStamped = tfBuffer.lookupTransform("turtle2", "turtle1", past, ros::Duration(1.0)); }}} ##explainstart So now, if you would run this, what would you expect to see? Definitely during the first 5 seconds the second turtle would not know where to go, because we do not yet have a 5 second history of the first turtle. But what after these 5 seconds? Let's just give it a try: {{{ $ catkin_make $ roslaunch learning_tf2 start_demo.launch }}} {{attachment:random.png}} Is your turtle driving around uncontrollably like in this screenshot? So what is happening? * We asked tf2, ''"What was the pose of `/turtle1` 5 seconds ago, relative to `/turtle2` 5 seconds ago?"''. This means we are controlling the second turtle based on where it was 5 seconds ago as well as where the first turtle was 5 seconds ago. * What we really want to ask is, ''"What was the pose of `/turtle1` 5 seconds ago, relative to the current position of the `/turtle2`?"''. == Advanced API for lookupTransform == So how can we ask tf2 a question like that? This API gives us the power to say explicitly when each frame is transformed. This is what the code would look like: ##explainend {{{ try{ ros::Time now = ros::Time::now(); ros::Time past = now - ros::Duration(5.0); transformStamped = tfBuffer.lookupTransform("turtle2", now, "turtle1", past, "world", ros::Duration(1.0)); }}} ##advancestart The advanced API for `lookupTransform()` takes six arguments: 1. Give the transform from this frame, 1. at this time ... 1. ... to this frame, 1. at this time. 1. Specify the frame that does not change over time, in this case the "/world" frame, and 1. the time-out. {{attachment:time_travel.png}} This figure shows what tf2 is doing in the background. In the past it computes the transform from the first turtle to the world. In the world frame tf2 time travels from the past to now. And at time now tf2 computes the transform from the world to the second turtle. == Checking the results == Let's run the simulator again, this time with the advanced time-travel API: ##advancedend {{{ $ catkin_make $ roslaunch learning_tf2 start_demo.launch }}} And yes, the second turtle is directed to where the first turtle was 5 seconds ago! ## AUTOGENERATED DO NOT DELETE ## TutorialCategory ## TutorialTurtlesim ## C++Category ## LearningCategory