1*d9f75844SAndroid Build Coastguard Worker /* 2*d9f75844SAndroid Build Coastguard Worker * Copyright 2012 The WebRTC Project Authors. All rights reserved. 3*d9f75844SAndroid Build Coastguard Worker * 4*d9f75844SAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license 5*d9f75844SAndroid Build Coastguard Worker * that can be found in the LICENSE file in the root of the source 6*d9f75844SAndroid Build Coastguard Worker * tree. An additional intellectual property rights grant can be found 7*d9f75844SAndroid Build Coastguard Worker * in the file PATENTS. All contributing project authors may 8*d9f75844SAndroid Build Coastguard Worker * be found in the AUTHORS file in the root of the source tree. 9*d9f75844SAndroid Build Coastguard Worker */ 10*d9f75844SAndroid Build Coastguard Worker 11*d9f75844SAndroid Build Coastguard Worker #ifndef RTC_BASE_DATA_RATE_LIMITER_H_ 12*d9f75844SAndroid Build Coastguard Worker #define RTC_BASE_DATA_RATE_LIMITER_H_ 13*d9f75844SAndroid Build Coastguard Worker 14*d9f75844SAndroid Build Coastguard Worker #include <stddef.h> 15*d9f75844SAndroid Build Coastguard Worker 16*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/system/rtc_export.h" 17*d9f75844SAndroid Build Coastguard Worker 18*d9f75844SAndroid Build Coastguard Worker namespace rtc { 19*d9f75844SAndroid Build Coastguard Worker 20*d9f75844SAndroid Build Coastguard Worker // Limits the rate of use to a certain maximum quantity per period of 21*d9f75844SAndroid Build Coastguard Worker // time. Use, for example, for simple bandwidth throttling. 22*d9f75844SAndroid Build Coastguard Worker // 23*d9f75844SAndroid Build Coastguard Worker // It's implemented like a diet plan: You have so many calories per 24*d9f75844SAndroid Build Coastguard Worker // day. If you hit the limit, you can't eat any more until the next 25*d9f75844SAndroid Build Coastguard Worker // day. 26*d9f75844SAndroid Build Coastguard Worker class RTC_EXPORT DataRateLimiter { 27*d9f75844SAndroid Build Coastguard Worker public: 28*d9f75844SAndroid Build Coastguard Worker // For example, 100kb per second. DataRateLimiter(size_t max,double period)29*d9f75844SAndroid Build Coastguard Worker DataRateLimiter(size_t max, double period) 30*d9f75844SAndroid Build Coastguard Worker : max_per_period_(max), 31*d9f75844SAndroid Build Coastguard Worker period_length_(period), 32*d9f75844SAndroid Build Coastguard Worker used_in_period_(0), 33*d9f75844SAndroid Build Coastguard Worker period_start_(0.0), 34*d9f75844SAndroid Build Coastguard Worker period_end_(period) {} ~DataRateLimiter()35*d9f75844SAndroid Build Coastguard Worker virtual ~DataRateLimiter() {} 36*d9f75844SAndroid Build Coastguard Worker 37*d9f75844SAndroid Build Coastguard Worker // Returns true if if the desired quantity is available in the 38*d9f75844SAndroid Build Coastguard Worker // current period (< (max - used)). Once the given time passes the 39*d9f75844SAndroid Build Coastguard Worker // end of the period, used is set to zero and more use is available. 40*d9f75844SAndroid Build Coastguard Worker bool CanUse(size_t desired, double time); 41*d9f75844SAndroid Build Coastguard Worker // Increment the quantity used this period. If past the end of a 42*d9f75844SAndroid Build Coastguard Worker // period, a new period is started. 43*d9f75844SAndroid Build Coastguard Worker void Use(size_t used, double time); 44*d9f75844SAndroid Build Coastguard Worker used_in_period()45*d9f75844SAndroid Build Coastguard Worker size_t used_in_period() const { return used_in_period_; } 46*d9f75844SAndroid Build Coastguard Worker max_per_period()47*d9f75844SAndroid Build Coastguard Worker size_t max_per_period() const { return max_per_period_; } 48*d9f75844SAndroid Build Coastguard Worker 49*d9f75844SAndroid Build Coastguard Worker private: 50*d9f75844SAndroid Build Coastguard Worker size_t max_per_period_; 51*d9f75844SAndroid Build Coastguard Worker double period_length_; 52*d9f75844SAndroid Build Coastguard Worker size_t used_in_period_; 53*d9f75844SAndroid Build Coastguard Worker double period_start_; 54*d9f75844SAndroid Build Coastguard Worker double period_end_; 55*d9f75844SAndroid Build Coastguard Worker }; 56*d9f75844SAndroid Build Coastguard Worker } // namespace rtc 57*d9f75844SAndroid Build Coastguard Worker 58*d9f75844SAndroid Build Coastguard Worker #endif // RTC_BASE_DATA_RATE_LIMITER_H_ 59