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

◆ analyze_implementation()

template<ComputeData InputType = std::vector<Kakshya::DataVariant>, ComputeData OutputType = Eigen::VectorXd>
output_type MayaFlux::Yantra::StatisticalAnalyzer< InputType, OutputType >::analyze_implementation ( const input_type input)
inlineoverrideprotectedvirtual

Core analysis implementation - creates analysis result AND pipeline output.

Parameters
inputInput data wrapped in Datum container
Returns
Pipeline output (data flow for chaining operations)

Implements MayaFlux::Yantra::UniversalAnalyzer< InputType, OutputType >.

Definition at line 355 of file StatisticalAnalyzer.hpp.

356 {
357 if constexpr (requires { input.data.empty(); }) {
358 if (input.data.empty()) {
359 error<std::runtime_error>(Journal::Component::Yantra, Journal::Context::ComputeMatrix, std::source_location::current(), "Input is empty");
360 }
361 } else if constexpr (std::is_same_v<InputType, Kakshya::RegionGroup>) {
362 if (input.data.regions.empty()) {
363 error<std::runtime_error>(Journal::Component::Yantra, Journal::Context::ComputeMatrix, std::source_location::current(), "Input is empty");
364 }
365 }
366 try {
367 auto [data_span, structure_info] = OperationHelper::extract_structured_double(
368 const_cast<input_type&>(input));
369
370 std::vector<std::span<const double>> channel_spans;
371 for (const auto& span : data_span)
372 channel_spans.emplace_back(span.data(), span.size());
373
374 std::vector<std::vector<double>> stat_values;
375 stat_values.reserve(channel_spans.size());
376 for (const auto& ch_span : channel_spans) {
377 stat_values.push_back(compute_statistical_values(ch_span, m_method));
378 }
379
380 StatisticalAnalysis analysis_result = create_analysis_result(
381 stat_values, channel_spans, structure_info);
382
383 this->store_current_analysis(analysis_result);
384 return create_pipeline_output(input, analysis_result, structure_info);
385 } catch (const std::exception& e) {
386 MF_ERROR(Journal::Component::Yantra, Journal::Context::ComputeMatrix, "Statistical analysis failed: {}", e.what());
387 output_type error_result;
388 error_result.metadata = input.metadata;
389 error_result.metadata["error"] = std::string("Analysis failed: ") + e.what();
390 return error_result;
391 }
392 }
#define MF_ERROR(comp, ctx,...)
Range size
static std::tuple< std::vector< std::span< double > >, DataStructureInfo > extract_structured_double(T &compute_data)
Extract structured double data from Datum container or direct ComputeData with automatic container ha...
StatisticalAnalysis create_analysis_result(const std::vector< std::vector< double > > &stat_values, std::vector< std::span< const double > > original_data, const auto &) const
Create comprehensive analysis result.
std::vector< double > compute_statistical_values(std::span< const double > data, StatisticalMethod method) const
Compute statistical values using span (zero-copy processing)
output_type create_pipeline_output(const input_type &input, const StatisticalAnalysis &analysis_result, DataStructureInfo &info)
Create pipeline output for operation chaining.
void store_current_analysis(AnalysisResultType &&result) const
@ ComputeMatrix
Compute operations (Yantra - algorithms, matrices, DSP)
@ Yantra
DSP algorithms, computational units, matrix operations, Grammar.
std::unordered_map< std::string, std::any > metadata
Associated metadata.
Definition DataIO.hpp:28

References MayaFlux::Yantra::Datum< T >::data, MayaFlux::Yantra::Datum< T >::metadata, and MF_ERROR.