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

◆ merge_chunks_to_result()

template<ComputeData InputType = Kakshya::DataVariant, ComputeData OutputType = InputType>
output_type MayaFlux::Yantra::StandardSorter< InputType, OutputType >::merge_chunks_to_result ( const std::vector< InputType > &  chunks,
const input_type original_input,
DataStructureInfo  info 
)
inlineprivate

Merge chunks back to single result.

Definition at line 299 of file StandardSorter.hpp.

300 {
301 output_type result {};
302 result.metadata = original_input.metadata;
303 result.metadata["sort_type"] = "chunked_merged";
304
305 if constexpr (std::same_as<InputType, OutputType>) {
306 if (chunks.empty()) {
307 return result;
308 }
309
310 try {
311 std::vector<std::vector<double>> merged_channels;
312
313 for (const auto& chunk : chunks) {
314 auto chunk_channels = OperationHelper::extract_numeric_data(chunk);
315
316 if (merged_channels.empty()) {
317 merged_channels.resize(chunk_channels.size());
318 }
319
320 for (size_t ch = 0; ch < chunk_channels.size() && ch < merged_channels.size(); ++ch) {
321 merged_channels[ch].insert(merged_channels[ch].end(),
322 chunk_channels[ch].begin(), chunk_channels[ch].end());
323 }
324 }
325
326 result = this->convert_result(merged_channels, info);
327 result.metadata = original_input.metadata;
328 result.metadata["sort_type"] = "chunked_merged";
329
330 } catch (...) {
331 result.data = chunks[0];
332 }
333 }
334
335 return result;
336 }
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::span< double > extract_numeric_data(const T &compute_data)
extract numeric data from single-variant types
typename base_type::output_type output_type
std::unordered_map< std::string, std::any > metadata
Associated metadata.
Definition DataIO.hpp:28