15#include <seqan3/core/algorithm/detail/execution_handler_parallel.hpp>
16#include <seqan3/utility/views/chunk.hpp>
17#include <seqan3/utility/views/zip.hpp>
22template <
typename algorithm_t>
23void call_parallel_on_bins(algorithm_t && worker,
25 uint8_t
const threads)
28 size_t const chunk_size = std::clamp<size_t>(
std::bit_ceil(bin_paths.size() / threads), 8u, 64u);
30 auto chunked_view = seqan3::views::zip(bin_paths, std::views::iota(0u)) | seqan3::views::chunk(chunk_size);
31 seqan3::detail::execution_handler_parallel executioner{threads};
32 executioner.bulk_execute(std::move(worker), std::move(chunked_view), []() {});