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

◆ create_pipeline_output()

template<ComputeData InputType = std::vector<Kakshya::DataVariant>, ComputeData OutputType = Eigen::VectorXd>
output_type MayaFlux::Yantra::StatisticalAnalyzer< InputType, OutputType >::create_pipeline_output ( const input_type input,
const StatisticalAnalysis analysis_result,
DataStructureInfo info 
)
inlineprivate

Create pipeline output for operation chaining.

Definition at line 622 of file StatisticalAnalyzer.hpp.

623 {
624 std::vector<std::vector<double>> channel_stats;
625 channel_stats.reserve(analysis_result.channel_statistics.size());
626 for (const auto& ch : analysis_result.channel_statistics) {
627 channel_stats.push_back(ch.statistical_values);
628 }
629
630 output_type output = this->convert_result(channel_stats, info);
631
632 output.metadata = input.metadata;
633
634 output.metadata["source_analyzer"] = "StatisticalAnalyzer";
635 output.metadata["statistical_method"] = method_to_string(analysis_result.method_used);
636 output.metadata["window_size"] = analysis_result.window_size;
637 output.metadata["hop_size"] = analysis_result.hop_size;
638 output.metadata["num_channels"] = analysis_result.channel_statistics.size();
639
640 if (!analysis_result.channel_statistics.empty()) {
641 std::vector<double> channel_means, channel_maxs, channel_mins, channel_variances, channel_stddevs, channel_skewness, channel_kurtosis, channel_medians;
642 std::vector<size_t> channel_window_counts;
643
644 for (const auto& ch : analysis_result.channel_statistics) {
645 channel_means.push_back(ch.mean_stat);
646 channel_maxs.push_back(ch.max_stat);
647 channel_mins.push_back(ch.min_stat);
648 channel_variances.push_back(ch.stat_variance);
649 channel_stddevs.push_back(ch.stat_std_dev);
650 channel_skewness.push_back(ch.skewness);
651 channel_kurtosis.push_back(ch.kurtosis);
652 channel_medians.push_back(ch.median);
653 channel_window_counts.push_back(ch.statistical_values.size());
654 }
655
656 output.metadata["mean_per_channel"] = channel_means;
657 output.metadata["max_per_channel"] = channel_maxs;
658 output.metadata["min_per_channel"] = channel_mins;
659 output.metadata["variance_per_channel"] = channel_variances;
660 output.metadata["stddev_per_channel"] = channel_stddevs;
661 output.metadata["skewness_per_channel"] = channel_skewness;
662 output.metadata["kurtosis_per_channel"] = channel_kurtosis;
663 output.metadata["median_per_channel"] = channel_medians;
664 output.metadata["window_count_per_channel"] = channel_window_counts;
665 }
666
667 return output;
668 }
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.
static std::string method_to_string(StatisticalMethod method)
Convert statistical method enum to string.

References MayaFlux::Yantra::StatisticalAnalysis::channel_statistics, MayaFlux::Yantra::StatisticalAnalysis::hop_size, MayaFlux::Yantra::IO< T >::metadata, MayaFlux::Yantra::StatisticalAnalysis::method_used, and MayaFlux::Yantra::StatisticalAnalysis::window_size.