Create pipeline output from input and energy values.
512 {
513 std::vector<std::vector<double>> channel_energies;
514 channel_energies.reserve(analysis_result.channels.size());
515
516 for (const auto& ch : analysis_result.channels) {
517 channel_energies.push_back(ch.energy_values);
518 }
519
521
522 output.metadata = input.metadata;
523
524 output.metadata["source_analyzer"] = "EnergyAnalyzer";
525 output.metadata[
"energy_method"] =
method_to_string(analysis_result.method_used);
526 output.metadata["window_size"] = analysis_result.window_size;
527 output.metadata["hop_size"] = analysis_result.hop_size;
528 output.metadata["num_channels"] = analysis_result.channels.size();
529
530 if (!analysis_result.channels.empty()) {
531 std::vector<double> channel_means, channel_maxs, channel_mins, channel_variances;
532 std::vector<size_t> channel_window_counts;
533
534 for (const auto& ch : analysis_result.channels) {
535 channel_means.push_back(ch.mean_energy);
536 channel_maxs.push_back(ch.max_energy);
537 channel_mins.push_back(ch.min_energy);
538 channel_variances.push_back(ch.variance);
539 channel_window_counts.push_back(ch.energy_values.size());
540 }
541
542 output.metadata["mean_energy_per_channel"] = channel_means;
543 output.metadata["max_energy_per_channel"] = channel_maxs;
544 output.metadata["min_energy_per_channel"] = channel_mins;
545 output.metadata["variance_per_channel"] = channel_variances;
546 output.metadata["window_count_per_channel"] = channel_window_counts;
547 }
548
549 return output;
550 }
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.
IO< OutputType > output_type
static std::string method_to_string(EnergyMethod method)
Convert energy method enum to string.