A class to keep a sorted linked list in time This builds and maintains a list of timestamped data. And provides lookup functions to get data out as a function of time. More...
#include <time_cache.h>
Public Member Functions | |
virtual void | clearList () |
Clear the list of stored values. More... | |
virtual bool | getData (ros::Time time, TransformStorage &data_out, std::string *error_str=0) |
Virtual methods. More... | |
virtual P_TimeAndFrameID | getLatestTimeAndParent () |
Get the latest time stored in this cache, and the parent associated with it. Returns parent = 0 if no data. More... | |
virtual ros::Time | getLatestTimestamp () |
Get the latest timestamp cached. More... | |
virtual unsigned int | getListLength () |
Debugging information methods. More... | |
virtual ros::Time | getOldestTimestamp () |
Get the oldest timestamp cached. More... | |
virtual CompactFrameID | getParent (ros::Time time, std::string *error_str) |
Retrieve the parent at a specific time. More... | |
virtual bool | insertData (const TransformStorage &new_data) |
Insert data into the cache. More... | |
TimeCache (ros::Duration max_storage_time=ros::Duration().fromNSec(DEFAULT_MAX_STORAGE_TIME)) | |
Static Public Attributes | |
static const int64_t | DEFAULT_MAX_STORAGE_TIME = 10ULL * 1000000000LL |
default value of 10 seconds storage More... | |
static const unsigned int | MAX_LENGTH_LINKED_LIST = 1000000 |
Maximum length of linked list, to make sure not to be able to use unlimited memory. More... | |
static const int | MIN_INTERPOLATION_DISTANCE = 5 |
Number of nano-seconds to not interpolate below. More... | |
Private Types | |
typedef std::deque< TransformStorage > | L_TransformStorage |
Private Member Functions | |
uint8_t | findClosest (TransformStorage *&one, TransformStorage *&two, ros::Time target_time, std::string *error_str) |
A helper function for getData. More... | |
void | interpolate (const TransformStorage &one, const TransformStorage &two, ros::Time time, TransformStorage &output) |
void | pruneList () |
Private Attributes | |
ros::Duration | max_storage_time_ |
L_TransformStorage | storage_ |
A class to keep a sorted linked list in time This builds and maintains a list of timestamped data. And provides lookup functions to get data out as a function of time.
Definition at line 94 of file time_cache.h.
|
private |
Definition at line 119 of file time_cache.h.
tf2::TimeCache::TimeCache | ( | ros::Duration | max_storage_time = ros::Duration().fromNSec(DEFAULT_MAX_STORAGE_TIME) | ) |
|
virtual |
Clear the list of stored values.
Implements tf2::TimeCacheInterface.
|
inlineprivate |
|
virtual |
|
virtual |
Get the latest time stored in this cache, and the parent associated with it. Returns parent = 0 if no data.
Implements tf2::TimeCacheInterface.
|
virtual |
Get the latest timestamp cached.
Implements tf2::TimeCacheInterface.
|
virtual |
Debugging information methods.
Implements tf2::TimeCacheInterface.
|
virtual |
Get the oldest timestamp cached.
Implements tf2::TimeCacheInterface.
|
virtual |
Retrieve the parent at a specific time.
Implements tf2::TimeCacheInterface.
|
virtual |
Insert data into the cache.
Implements tf2::TimeCacheInterface.
|
inlineprivate |
|
static |
default value of 10 seconds storage
Definition at line 99 of file time_cache.h.
|
static |
Maximum length of linked list, to make sure not to be able to use unlimited memory.
Definition at line 98 of file time_cache.h.
|
private |
Definition at line 122 of file time_cache.h.
|
static |
Number of nano-seconds to not interpolate below.
Definition at line 97 of file time_cache.h.
|
private |
Definition at line 120 of file time_cache.h.