1#include <vanetza/geonet/cbr_aggregator.hpp>
2#include <vanetza/geonet/location_table.hpp>
3#include <vanetza/geonet/loctex_g5.hpp>
12struct CbrAggregatorUnit
14 CbrAggregatorUnit() : n(0) {}
16 void operator+=(dcc::ChannelLoad cbr)
19 average = dcc::ChannelLoad {(average.value() * n + cbr.value()) / (n + 1)};
23 if (cbr >= maximum[0]) {
24 maximum[1] = maximum[0];
26 }
else if (cbr > maximum[1]) {
31 dcc::ChannelLoad operator()(
const dcc::ChannelLoad target)
const
33 if (average > target) {
41 dcc::ChannelLoad average;
42 std::array<dcc::ChannelLoad, 2> maximum;
45CbrAggregator::CbrAggregator() :
46 m_one_hop_cbr(0.0), m_two_hop_cbr(0.0)
52 m_local_cbr[1] = m_local_cbr[0];
53 m_local_cbr[0] = local;
55 CbrAggregatorUnit one_hop;
56 CbrAggregatorUnit two_hop;
58 LocationTable::entry_visitor entry_visitor =
61 if (loctex && loctex->local_update >= lifetime) {
62 one_hop += loctex->dcc_mco.local_cbr();
63 two_hop += loctex->dcc_mco.neighbour_cbr();
66 lt.visit(entry_visitor);
68 m_one_hop_cbr = one_hop(target);
69 m_two_hop_cbr = two_hop(target);
70 m_global_cbr = std::max({ m_local_cbr[1], m_one_hop_cbr, m_two_hop_cbr});