Vanetza
 
Loading...
Searching...
No Matches
cbr_aggregator.cpp
1#include <vanetza/geonet/cbr_aggregator.hpp>
2#include <vanetza/geonet/location_table.hpp>
3#include <vanetza/geonet/loctex_g5.hpp>
4#include <algorithm>
5#include <array>
6
7namespace vanetza
8{
9namespace geonet
10{
11
12struct CbrAggregatorUnit
13{
14 CbrAggregatorUnit() : n(0) {}
15
16 void operator+=(dcc::ChannelLoad cbr)
17 {
18 // calculate average as double so numerator can be larger than 1.0 temporarily
19 average = dcc::ChannelLoad {(average.value() * n + cbr.value()) / (n + 1)};
20 ++n;
21
22 // >= comparison: second largest value might equal largest value
23 if (cbr >= maximum[0]) {
24 maximum[1] = maximum[0];
25 maximum[0] = cbr;
26 } else if (cbr > maximum[1]) {
27 maximum[1] = cbr;
28 }
29 }
30
31 dcc::ChannelLoad operator()(const dcc::ChannelLoad target) const
32 {
33 if (average > target) {
34 return maximum[0];
35 } else {
36 return maximum[1];
37 }
38 }
39
40 unsigned n;
41 dcc::ChannelLoad average;
42 std::array<dcc::ChannelLoad, 2> maximum;
43};
44
45CbrAggregator::CbrAggregator() :
46 m_one_hop_cbr(0.0), m_two_hop_cbr(0.0)
47{
48}
49
50void CbrAggregator::aggregate(ChannelLoad local, const LocationTable& lt, Timestamp lifetime, ChannelLoad target)
51{
52 m_local_cbr[1] = m_local_cbr[0];
53 m_local_cbr[0] = local;
54
55 CbrAggregatorUnit one_hop;
56 CbrAggregatorUnit two_hop;
57
58 LocationTable::entry_visitor entry_visitor =
59 [&](const MacAddress&, const LocationTableEntry& entry) {
60 const LocTEX_G5* loctex = entry.extensions.find<LocTEX_G5>();
61 if (loctex && loctex->local_update >= lifetime) {
62 one_hop += loctex->dcc_mco.local_cbr();
63 two_hop += loctex->dcc_mco.neighbour_cbr();
64 }
65 };
66 lt.visit(entry_visitor);
67
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});
71}
72
73} // namespace geonet
74} // namespace vanetza