47 std::vector<std::size_t> cell_offsets(local_cells.size(), std::size_t{0});
48 std::exclusive_scan(local_cells.begin(), local_cells.end(),
49 cell_offsets.begin(), std::size_t{0},
50 [](
auto acc,
auto const &cell) {
51 return acc + cell->particles().size();
55 "enumerate_local_particles", local_cells.size(), [&](
auto cell_idx) {
56 auto const base_offset = cell_offsets[cell_idx];
57 auto &cell_particles = local_cells[cell_idx]->particles();
58 auto const n_part = cell_particles.size();
59 for (std::size_t p_index{0}; p_index < n_part; ++p_index) {
60 auto global_index = base_offset + p_index;
61 kernel(global_index, *(cell_particles.begin() + p_index));
67 std::size_t index = 0;
68 for (
auto &p : cs.local_particles()) {
virtual std::span< Cell *const > local_cells() const =0
Get pointer to local cells.
void enumerate_local_particles(CellStructure const &cs, Kernel &&kernel)
Run a kernel on all local particles with enumeration.