2018-01-22 21:39:23 -05:00
|
|
|
//
|
|
|
|
// ConfidenceSummary.cpp
|
|
|
|
// Clock Signal
|
|
|
|
//
|
|
|
|
// Created by Thomas Harte on 21/01/2018.
|
|
|
|
// Copyright © 2018 Thomas Harte. All rights reserved.
|
|
|
|
//
|
|
|
|
|
|
|
|
#include "ConfidenceSummary.hpp"
|
|
|
|
|
|
|
|
#include <cassert>
|
|
|
|
#include <numeric>
|
|
|
|
|
2018-01-28 22:22:21 -05:00
|
|
|
using namespace Analyser::Dynamic;
|
2018-01-22 21:39:23 -05:00
|
|
|
|
|
|
|
ConfidenceSummary::ConfidenceSummary(const std::vector<ConfidenceSource *> &sources, const std::vector<float> &weights) :
|
|
|
|
sources_(sources), weights_(weights) {
|
|
|
|
assert(weights.size() == sources.size());
|
|
|
|
weight_sum_ = std::accumulate(weights.begin(), weights.end(), 0.0f);
|
|
|
|
}
|
|
|
|
|
2018-01-25 19:02:16 -05:00
|
|
|
float ConfidenceSummary::get_confidence() {
|
2018-01-22 21:39:23 -05:00
|
|
|
float result = 0.0f;
|
|
|
|
for(std::size_t index = 0; index < sources_.size(); ++index) {
|
2018-01-25 19:02:16 -05:00
|
|
|
result += sources_[index]->get_confidence() * weights_[index];
|
2018-01-22 21:39:23 -05:00
|
|
|
}
|
|
|
|
return result / weight_sum_;
|
|
|
|
}
|