mirror of
https://github.com/ton-blockchain/ton
synced 2025-03-09 15:40:10 +00:00
integrating the existing state of TON Storage / TON Payments / CPS Fift development branches
This commit is contained in:
parent
040df63c98
commit
4e2624459b
153 changed files with 10760 additions and 1695 deletions
45
rldp2/Pacer.cpp
Normal file
45
rldp2/Pacer.cpp
Normal file
|
@ -0,0 +1,45 @@
|
|||
#include "Pacer.h"
|
||||
namespace ton {
|
||||
namespace rldp2 {
|
||||
Pacer::Pacer(Options options)
|
||||
: speed_(options.initial_speed)
|
||||
, capacity_(options.initial_capacity)
|
||||
, max_capacity_(options.max_capacity)
|
||||
, time_granularity_(options.time_granularity) {
|
||||
}
|
||||
|
||||
td::Timestamp Pacer::wakeup_at() const {
|
||||
return wakeup_at_;
|
||||
}
|
||||
|
||||
void Pacer::set_speed(double speed) {
|
||||
if (speed < 1) {
|
||||
speed = 1;
|
||||
}
|
||||
speed_ = speed;
|
||||
}
|
||||
|
||||
td::optional<td::Timestamp> Pacer::send(double size, td::Timestamp now) {
|
||||
update_capacity(now);
|
||||
|
||||
if (size < capacity_) {
|
||||
capacity_ -= size;
|
||||
return {};
|
||||
}
|
||||
|
||||
size -= capacity_;
|
||||
capacity_ = 0;
|
||||
wakeup_at_ = td::Timestamp::in(size / speed_, now);
|
||||
capacity_at_ = wakeup_at_;
|
||||
return wakeup_at_;
|
||||
}
|
||||
|
||||
void Pacer::update_capacity(td::Timestamp now) {
|
||||
if (capacity_at_ && capacity_at_.is_in_past(now)) {
|
||||
capacity_ += (now.at() - capacity_at_.at()) * speed_;
|
||||
capacity_ = td::min(capacity_, td::max(max_capacity_, speed_ * time_granularity_));
|
||||
}
|
||||
capacity_at_ = now;
|
||||
}
|
||||
} // namespace rldp2
|
||||
} // namespace ton
|
Loading…
Add table
Add a link
Reference in a new issue