MayaFlux 0.4.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 557 of file StatisticalAnalyzer.hpp.

559 {
560 namespace D = MayaFlux::Kinesis::Discrete;
561
562 StatisticalAnalysis result;
563 result.method_used = m_method;
564 result.window_size = m_window_size;
565 result.hop_size = m_hop_size;
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...); });
592 channel_result.stat_variance = single([&](auto&&... a) { return D::variance(a..., m_sample_variance); });
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 = {
599 D::percentile(sp, 1, 0, sz, 25.0)[0],
600 channel_result.median,
601 D::percentile(sp, 1, 0, sz, 75.0)[0]
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) {
607 const size_t start = i * m_hop_size;
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) {
617 const StatisticalLevel level = classify_statistical_level(value);
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 }
size_t a
StatisticalLevel classify_statistical_level(double value) const
Classify statistical value qualitatively.
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
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 > 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 > 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
StatisticalLevel
Qualitative classification of statistical values.

References a, MayaFlux::Yantra::StatisticalAnalysis::channel_statistics, MayaFlux::Yantra::StatisticalAnalyzer< InputType, OutputType >::classify_statistical_level(), MayaFlux::Yantra::StatisticalAnalysis::hop_size, MayaFlux::Kinesis::Discrete::kurtosis(), MayaFlux::Yantra::StatisticalAnalyzer< InputType, OutputType >::m_classification_enabled, MayaFlux::Yantra::StatisticalAnalyzer< InputType, OutputType >::m_hop_size, MayaFlux::Yantra::StatisticalAnalyzer< InputType, OutputType >::m_method, MayaFlux::Yantra::StatisticalAnalyzer< InputType, OutputType >::m_sample_variance, MayaFlux::Yantra::StatisticalAnalyzer< InputType, OutputType >::m_window_size, MayaFlux::Kinesis::Discrete::mean(), MayaFlux::Kinesis::Discrete::median(), MayaFlux::Yantra::StatisticalAnalysis::method_used, MayaFlux::Kinesis::Discrete::percentile(), MayaFlux::Kinesis::Discrete::skewness(), MayaFlux::Kinesis::Discrete::variance(), and MayaFlux::Yantra::StatisticalAnalysis::window_size.

Referenced by MayaFlux::Yantra::StatisticalAnalyzer< InputType, OutputType >::analyze_implementation().

+ Here is the call graph for this function:
+ Here is the caller graph for this function: