Create comprehensive analysis result.
559 {
561
562 StatisticalAnalysis result;
566
567 if (stat_values.empty()) {
568 return result;
569 }
570
571 result.channel_statistics.resize(stat_values.size());
572
573 for (size_t ch = 0; ch < stat_values.size(); ++ch) {
574 auto& channel_result = result.channel_statistics[ch];
575 const auto& ch_stats = stat_values[ch];
576
577 channel_result.statistical_values = ch_stats;
578
579 if (ch_stats.empty())
580 continue;
581
582 const auto [min_it, max_it] = std::ranges::minmax_element(ch_stats);
583 channel_result.min_stat = *min_it;
584 channel_result.max_stat = *max_it;
585
586 const std::span<const double> sp(ch_stats);
587 const auto sz = static_cast<uint32_t>(ch_stats.size());
588
589 const auto single = [&](auto fn) { return fn(sp, 1, 0, sz)[0]; };
590
591 channel_result.mean_stat = single([](
auto&&...
a) {
return D::mean(
a...); });
593 channel_result.stat_std_dev = std::sqrt(channel_result.stat_variance);
594 channel_result.skewness = single([](
auto&&...
a) {
return D::skewness(
a...); });
595 channel_result.kurtosis = single([](
auto&&...
a) {
return D::kurtosis(
a...); });
596 channel_result.median = single([](
auto&&...
a) {
return D::median(
a...); });
597
598 channel_result.percentiles = {
600 channel_result.median,
602 };
603
604 const size_t data_size = (ch < original_data.size()) ? original_data[ch].size() : 0;
605 channel_result.window_positions.reserve(ch_stats.size());
606 for (size_t i = 0; i < ch_stats.size(); ++i) {
608 const size_t end = std::min(start +
m_window_size, data_size);
609 channel_result.window_positions.emplace_back(start, end);
610 }
611
613 channel_result.stat_classifications.reserve(ch_stats.size());
614 channel_result.level_counts.fill(0);
615
616 for (double value : ch_stats) {
618 channel_result.stat_classifications.push_back(level);
619 channel_result.level_counts[static_cast<size_t>(level)]++;
620 }
621 }
622 }
623
624 return result;
625 }
StatisticalMethod m_method
StatisticalLevel classify_statistical_level(double value) const
Classify statistical value qualitatively.
bool m_classification_enabled
std::vector< double > percentile(std::span< const double > data, size_t n_windows, uint32_t hop_size, uint32_t window_size, double percentile_value)
Arbitrary percentile per window via linear interpolation.
std::vector< double > variance(std::span< const double > data, size_t n_windows, uint32_t hop_size, uint32_t window_size, bool sample_variance)
Variance per window.
std::vector< double > skewness(std::span< const double > data, size_t n_windows, uint32_t hop_size, uint32_t window_size)
Skewness (standardised third central moment) per window.
std::vector< double > kurtosis(std::span< const double > data, size_t n_windows, uint32_t hop_size, uint32_t window_size)
Excess kurtosis (fourth central moment - 3) per window.
std::vector< double > median(std::span< const double > data, size_t n_windows, uint32_t hop_size, uint32_t window_size)
Median per window via nth_element partial sort.
std::vector< double > mean(std::span< const double > data, size_t n_windows, uint32_t hop_size, uint32_t window_size)
Arithmetic mean per window.
StatisticalLevel
Qualitative classification of statistical values.