Select Git revision
antennaselector.cpp
Code owners
Assign users and groups as approvers for specific file changes. Learn more.
antennaselector.cpp 1.49 KiB
#include "antennaselector.h"
#include "../../quality/statisticscollection.h"
#include "../../quality/statisticsderivator.h"
using std::size_t;
namespace algorithms {
std::vector<size_t> AntennaSelector::Run(
const StatisticsCollection& statisticsCollection) {
std::map<size_t, DefaultStatistics> antStatistics =
statisticsCollection.GetAntennaStatistics();
std::vector<double> stddevs;
std::set<size_t> badAntennas;
for (size_t p = 0; p != 4; ++p) {
double meanStddev = 0.0;
stddevs.clear();
for (const std::pair<const size_t, DefaultStatistics>& antenna : antStatistics) {
double stddev = StatisticsDerivator::GetStatisticAmplitude(
QualityTablesFormatter::StandardDeviationStatistic, antenna.second,
p);
stddevs.emplace_back(stddev);
meanStddev += stddev;
}
double stddevOfStddev = 0.0;
meanStddev /= stddevs.size();
for (double& s : stddevs) {
stddevOfStddev += (s - meanStddev) * (s - meanStddev);
}
stddevOfStddev = sqrt(stddevOfStddev / stddevs.size());
size_t index = 0;
double limit = _threshold * stddevOfStddev;
for (const std::pair<const size_t, DefaultStatistics>& antenna : antStatistics) {
if (std::fabs(stddevs[index] - meanStddev) > limit ||
stddevs[index] == 0.0) {
if (antenna.second.count[p] != 0) badAntennas.insert(antenna.first);
}
++index;
}
}
return std::vector<size_t>(badAntennas.begin(), badAntennas.end());
}
} // namespace algorithms