MayaFlux 0.3.0
Digital-First Multimedia Processing Framework
Loading...
Searching...
No Matches

◆ create_analysis_result()

template<ComputeData InputType = std::vector<Kakshya::DataVariant>, ComputeData OutputType = Eigen::VectorXd>
StatisticalAnalysis MayaFlux::Yantra::StatisticalAnalyzer< InputType, OutputType >::create_analysis_result ( const std::vector< std::vector< double > > &  stat_values,
std::vector< std::span< const double > >  original_data,
const auto &   
) const
inlineprivate

Create comprehensive analysis result.

Definition at line 547 of file StatisticalAnalyzer.hpp.

549 {
550 namespace D = MayaFlux::Kinesis::Discrete;
551
552 StatisticalAnalysis result;
553 result.method_used = m_method;
554 result.window_size = m_window_size;
555 result.hop_size = m_hop_size;
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...); });
582 channel_result.stat_variance = single([&](auto&&... a) { return D::variance(a..., m_sample_variance); });
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 = {
589 D::percentile(sp, 1, 0, sz, 25.0)[0],
590 channel_result.median,
591 D::percentile(sp, 1, 0, sz, 75.0)[0]
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) {
597 const size_t start = i * m_hop_size;
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) {
607 const StatisticalLevel level = classify_statistical_level(value);
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 }
size_t a
StatisticalLevel classify_statistical_level(double value) const
Classify statistical value qualitatively.
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.
Definition Analysis.cpp:200
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.
Definition Analysis.cpp:325
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.
Definition Analysis.cpp:219
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.
Definition Analysis.cpp:259
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.
Definition Analysis.cpp:292
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.
Definition Analysis.cpp:350
StatisticalLevel
Qualitative classification of statistical values.

References a, MayaFlux::Yantra::StatisticalAnalysis::channel_statistics, MayaFlux::Yantra::StatisticalAnalysis::hop_size, MayaFlux::Yantra::StatisticalAnalysis::method_used, and MayaFlux::Yantra::StatisticalAnalysis::window_size.