rate_limiter.h
Go to the documentation of this file.
1 #pragma once
2 
11 #include <ros/duration.h>
12 #include <ros/rate.h>
13 #include <ros/time.h>
14 
15 namespace cras
16 {
17 
22 {
23 public:
28  explicit RateLimiter(const ::ros::Rate& rate);
29 
34  explicit RateLimiter(const ::ros::Duration& period);
35 
42  virtual bool shouldPublish(const ::ros::Time& stamp) = 0;
43 
47  virtual void reset() = 0;
48 
55  void setJumpBackTolerance(const ::ros::Duration& tolerance);
56 
57 protected:
64  bool jumpedBack(const ::ros::Time& stamp, const ::ros::Time& previousStamp) const;
65 
68 
71 
74 };
75 
81 {
82 public:
83  explicit ThrottleLimiter(const ::ros::Rate& rate);
84  explicit ThrottleLimiter(const ::ros::Duration& period);
85 
86  bool shouldPublish(const ::ros::Time& stamp) override;
87  void reset() override;
88 
89 protected:
92 };
93 
104 {
105 public:
114  explicit TokenBucketLimiter(const ::ros::Rate& rate, size_t bucketCapacity = 2, double initialTokensAvailable = 1.0);
115 
124  explicit TokenBucketLimiter(const ::ros::Duration& period, size_t bucketCapacity = 2,
125  double initialTokensAvailable = 1.0);
126 
127  bool shouldPublish(const ::ros::Time& stamp) override;
128  void reset() override;
129 
130 protected:
133 
136 
140 
143 };
144 
145 }
cras::TokenBucketLimiter::initialTokensAvailable
double initialTokensAvailable
The number of tokens that are initially in the buffer (and after reset).
Definition: rate_limiter.h:142
cras
Definition: any.hpp:15
time.h
cras::TokenBucketLimiter::lastCheckTime
::ros::Time lastCheckTime
Stamp of the last incoming message. Zero at the beginning.
Definition: rate_limiter.h:132
cras::TokenBucketLimiter::shouldPublish
bool shouldPublish(const ::ros::Time &stamp) override
Call this function whenever a message is received. It tells whether the message has passed the rate-l...
cras::RateLimiter::jumpedBack
bool jumpedBack(const ::ros::Time &stamp, const ::ros::Time &previousStamp) const
Decide whether the newly coming message should be treated as a backwards jump in time.
cras::RateLimiter::reset
virtual void reset()=0
Reset the rate-limiter as if it were newly created with the same parameters.
cras::TokenBucketLimiter
Token bucket rate limiting algorithm.
Definition: rate_limiter.h:103
cras::RateLimiter::jumpBackTolerance
::ros::Duration jumpBackTolerance
Threshold for jump back detection.
Definition: rate_limiter.h:73
cras::RateLimiter::setJumpBackTolerance
void setJumpBackTolerance(const ::ros::Duration &tolerance)
Set the limit for telling between small and large backwards time jumps. Small jumps result in ignorin...
cras::RateLimiter::RateLimiter
RateLimiter(const ::ros::Rate &rate)
Create limiter with the given rate.
cras::RateLimiter
Generic rate-limiter interface.
Definition: rate_limiter.h:21
duration.h
cras::RateLimiter::rate
::ros::Rate rate
The desired rate (1/period).
Definition: rate_limiter.h:67
cras::ThrottleLimiter::lastPublishTime
::ros::Time lastPublishTime
Stamp of the last message for which shouldPublish() returned trued.
Definition: rate_limiter.h:91
cras::ThrottleLimiter::ThrottleLimiter
ThrottleLimiter(const ::ros::Rate &rate)
cras::TokenBucketLimiter::bucketCapacity
size_t bucketCapacity
Number of tokens that can fit into the bucket. This influences the maximum burst size.
Definition: rate_limiter.h:135
rate.h
cras::ThrottleLimiter
The (not so clever) algorithm used by topic_tools/throttle node.
Definition: rate_limiter.h:80
cras::TokenBucketLimiter::TokenBucketLimiter
TokenBucketLimiter(const ::ros::Rate &rate, size_t bucketCapacity=2, double initialTokensAvailable=1.0)
Create the rate-limiter limiting to the desired rate.
ros::Time
cras::ThrottleLimiter::reset
void reset() override
Reset the rate-limiter as if it were newly created with the same parameters.
cras::RateLimiter::shouldPublish
virtual bool shouldPublish(const ::ros::Time &stamp)=0
Call this function whenever a message is received. It tells whether the message has passed the rate-l...
cras::ThrottleLimiter::shouldPublish
bool shouldPublish(const ::ros::Time &stamp) override
Call this function whenever a message is received. It tells whether the message has passed the rate-l...
cras::TokenBucketLimiter::tokensAvailable
ros::Duration tokensAvailable
The number of currently available tokens. This units of this number are actually not seconds,...
Definition: rate_limiter.h:139
ros::Rate
cras::RateLimiter::period
::ros::Duration period
The desired period between message (1/rate).
Definition: rate_limiter.h:70
ros::Duration
cras::TokenBucketLimiter::reset
void reset() override
Reset the rate-limiter as if it were newly created with the same parameters.


cras_cpp_common
Author(s): Martin Pecka
autogenerated on Wed Jan 8 2025 03:50:07