Create pipeline output for operation chaining.
631 {
632 std::vector<std::vector<double>> channel_stats;
633 channel_stats.reserve(analysis_result.channel_statistics.size());
634 for (const auto& ch : analysis_result.channel_statistics) {
635 channel_stats.push_back(ch.statistical_values);
636 }
637
639
640 output.metadata =
input.metadata;
641
642 output.metadata["source_analyzer"] = "StatisticalAnalyzer";
643 output.metadata[
"statistical_method"] =
method_to_string(analysis_result.method_used);
644 output.metadata["window_size"] = analysis_result.window_size;
645 output.metadata["hop_size"] = analysis_result.hop_size;
646 output.metadata["num_channels"] = analysis_result.channel_statistics.size();
647
648 if (!analysis_result.channel_statistics.empty()) {
649 std::vector<double> channel_means, channel_maxs, channel_mins, channel_variances, channel_stddevs, channel_skewness, channel_kurtosis, channel_medians;
650 std::vector<size_t> channel_window_counts;
651
652 for (const auto& ch : analysis_result.channel_statistics) {
653 channel_means.push_back(ch.mean_stat);
654 channel_maxs.push_back(ch.max_stat);
655 channel_mins.push_back(ch.min_stat);
656 channel_variances.push_back(ch.stat_variance);
657 channel_stddevs.push_back(ch.stat_std_dev);
658 channel_skewness.push_back(ch.skewness);
659 channel_kurtosis.push_back(ch.kurtosis);
660 channel_medians.push_back(ch.median);
661 channel_window_counts.push_back(ch.statistical_values.size());
662 }
663
664 output.metadata["mean_per_channel"] = channel_means;
665 output.metadata["max_per_channel"] = channel_maxs;
666 output.metadata["min_per_channel"] = channel_mins;
667 output.metadata["variance_per_channel"] = channel_variances;
668 output.metadata["stddev_per_channel"] = channel_stddevs;
669 output.metadata["skewness_per_channel"] = channel_skewness;
670 output.metadata["kurtosis_per_channel"] = channel_kurtosis;
671 output.metadata["median_per_channel"] = channel_medians;
672 output.metadata["window_count_per_channel"] = channel_window_counts;
673 }
674
675 return output;
676 }
Core::GlobalInputConfig input
output_type convert_result(std::vector< std::vector< double > > &result_data, DataStructureInfo &metadata)
Convert processed double data back to OutputType using metadata and optional callback.
Datum< OutputType > output_type
static std::string method_to_string(StatisticalMethod method)
Convert statistical method enum to string.