Create comprehensive analysis result.
549 {
551
552 StatisticalAnalysis result;
556
557 if (stat_values.empty()) {
558 return result;
559 }
560
561 result.channel_statistics.resize(stat_values.size());
562
563 for (size_t ch = 0; ch < stat_values.size(); ++ch) {
564 auto& channel_result = result.channel_statistics[ch];
565 const auto& ch_stats = stat_values[ch];
566
567 channel_result.statistical_values = ch_stats;
568
569 if (ch_stats.empty())
570 continue;
571
572 const auto [min_it, max_it] = std::ranges::minmax_element(ch_stats);
573 channel_result.min_stat = *min_it;
574 channel_result.max_stat = *max_it;
575
576 const std::span<const double> sp(ch_stats);
577 const auto sz = static_cast<uint32_t>(ch_stats.size());
578
579 const auto single = [&](auto fn) { return fn(sp, 1, 0, sz)[0]; };
580
581 channel_result.mean_stat = single([](
auto&&...
a) {
return D::mean(
a...); });
583 channel_result.stat_std_dev = std::sqrt(channel_result.stat_variance);
584 channel_result.skewness = single([](
auto&&...
a) {
return D::skewness(
a...); });
585 channel_result.kurtosis = single([](
auto&&...
a) {
return D::kurtosis(
a...); });
586 channel_result.median = single([](
auto&&...
a) {
return D::median(
a...); });
587
588 channel_result.percentiles = {
590 channel_result.median,
592 };
593
594 const size_t data_size = (ch < original_data.size()) ? original_data[ch].size() : 0;
595 channel_result.window_positions.reserve(ch_stats.size());
596 for (size_t i = 0; i < ch_stats.size(); ++i) {
598 const size_t end = std::min(start +
m_window_size, data_size);
599 channel_result.window_positions.emplace_back(start, end);
600 }
601
603 channel_result.stat_classifications.reserve(ch_stats.size());
604 channel_result.level_counts.fill(0);
605
606 for (double value : ch_stats) {
608 channel_result.stat_classifications.push_back(level);
609 channel_result.level_counts[static_cast<size_t>(level)]++;
610 }
611 }
612 }
613
614 return result;
615 }
StatisticalMethod m_method
StatisticalLevel classify_statistical_level(double value) const
Classify statistical value qualitatively.
bool m_classification_enabled
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.
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 > 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 > 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.
StatisticalLevel
Qualitative classification of statistical values.