1#include "duty_cycle_permit.hpp"
2#include "limeric_budget.hpp"
3#include <vanetza/common/runtime.hpp>
14constexpr Clock::duration min_interval = std::chrono::milliseconds(25);
15constexpr Clock::duration max_interval = std::chrono::seconds(1);
18LimericBudget::LimericBudget(
const DutyCyclePermit& dcp,
const Runtime& rt) :
19 m_duty_cycle_permit(dcp), m_runtime(rt),
20 m_interval(min_interval), m_tx_start(Clock::time_point::min()),
21 m_tx_on(Clock::duration::zero())
26Clock::duration LimericBudget::delay()
28 Clock::duration delay = Clock::duration::max();
29 if (m_runtime.now() >= m_tx_start + m_interval) {
30 delay = Clock::duration::zero();
32 delay = m_tx_start + m_interval - m_runtime.now();
37Clock::duration LimericBudget::interval()
42void LimericBudget::notify(Clock::duration tx_on)
44 m_tx_start = m_runtime.now();
47 using std::chrono::duration_cast;
48 const auto duty_cycle = m_duty_cycle_permit.permitted_duty_cycle();
49 const auto interval = duration_cast<Clock::duration>(tx_on / duty_cycle.value());
50 m_interval = clamp_interval(interval);
53void LimericBudget::update()
55 using std::chrono::duration_cast;
56 using FloatingPointDuration = std::chrono::duration<double, Clock::period>;
57 const FloatingPointDuration delay = m_tx_start + m_interval - m_runtime.now();
58 const double duty_cycle = m_duty_cycle_permit.permitted_duty_cycle().value();
60 if (duty_cycle > 0.0) {
61 if (delay.count() > 0.0) {
63 const FloatingPointDuration interval = (m_tx_on / duty_cycle) * (delay / m_interval);
64 m_interval = clamp_interval(duration_cast<Clock::duration>(interval) + m_runtime.now() - m_tx_start);
67 const FloatingPointDuration interval = m_tx_on / duty_cycle;
68 m_interval = clamp_interval(duration_cast<Clock::duration>(interval));
72 m_interval = max_interval;
76Clock::duration LimericBudget::clamp_interval(Clock::duration interval)
const
78 return std::min(std::max(interval, min_interval), max_interval);