1#include "gradual_state_machine.hpp"
2#include <boost/format.hpp>
10GradualStateMachine::GradualStateMachine(
const std::set<State>& states) :
11 m_states(states), m_current(m_states.begin())
16GradualStateMachine::GradualStateMachine(std::set<State>&& states) :
17 m_states(
std::move(states)), m_current(m_states.begin())
24 static_assert(std::is_base_of<std::bidirectional_iterator_tag,
25 std::iterator_traits<StateContainer::const_iterator>::iterator_category>::value,
26 "State transitions require bidirectional iterators");
28 if (cbr < m_current->lower_limit) {
29 if (m_current != m_states.begin()) {
30 std::advance(m_current, -1);
33 StateContainer::const_iterator up = std::next(m_current);
34 if (up != m_states.end() && cbr >= up->lower_limit) {
40Clock::duration GradualStateMachine::transmission_interval()
const
42 return m_current->off_time;
45std::string GradualStateMachine::state()
const
47 if (m_current == m_states.begin()) {
49 }
else if (m_current == std::prev(m_states.end())) {
52 static const boost::format fmt(
"Active %1%");
53 return (boost::format(fmt) % std::distance(m_states.begin(), m_current)).str();
57void GradualStateMachine::repair()
59 if (m_states.empty()) {
60 m_states.emplace(ChannelLoad(0.0), Clock::duration::zero());
61 m_current = m_states.begin();