Merge chunks back to single result.
300 {
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) {
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
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.