1#ifndef __SIMULATION_KERNELS_HPP__
2#define __SIMULATION_KERNELS_HPP__
4#include <Kokkos_Core_fwd.hpp>
5#include <common/common.hpp>
6#include <common/kokkos_getpolicy.hpp>
7#include <mc/domain.hpp>
9#include <simulation/kernels/contribution_kernel.hpp>
10#include <simulation/kernels/model_kernel.hpp>
11#include <simulation/kernels/move_kernel.hpp>
13#include <common/execinfo.hpp>
18 template <
typename Space>
21 template <
typename Space>
24 template <
typename Space, ModelType Model>
struct CycleFunctors
55 const bool enable_leave = new_move.leaving_flow.size() != 0;
82 = Kokkos::create_mirror_view_and_copy(HostSpace(),
cycle_reducer)();
84 const auto host_out_counter
85 = Kokkos::create_mirror_view_and_copy(HostSpace(),
move_reducer)();
87 return std::tuple(host_red, host_out_counter);
103 std::move(_concentrations),
107 options.m_p_p_team_leave,
116 options.m_p_p_team_contribs, _contribs_scatter, container),
128 const auto npt =
m_options.m_p_p_team_move;
134 static_cast<int>(league_size),
138 cycle_policy.set_scratch_size(
139 0, Kokkos::PerTeam(
sizeof(float_t) * npt * 2));
141 Kokkos ::parallel_for(
"cycle_move", cycle_policy,
move_kernel);
147 const auto _policy_leave = Kokkos::RangePolicy<KernelInline::TagLeave>(
149 Kokkos ::parallel_reduce(
157 std::size_t league_size
160 const auto cycle_policy
162 static_cast<int>(league_size),
166 Kokkos::parallel_reduce(
183 "ModelType:Constapply_weight()");
188 const auto policy_contribs
189 = Kokkos::TeamPolicy<typename ContributionFunctor<Model>::Tag3D>(
190 model_space, league_size, Kokkos::AUTO(), Kokkos::AUTO());
191 Kokkos::parallel_for(
197 = Kokkos::TeamPolicy<typename ContributionFunctor<Model>::Tag0D>(
198 model_space, league_size, Kokkos::AUTO(), Kokkos::AUTO());
199 policy_contribs.set_scratch_size(
200 0, Kokkos::PerTeam(
sizeof(float_t) * Model::n_c));
201 Kokkos::parallel_for(
Main owning object for Monte-Carlo particles.
Definition particles_container.hpp:57
KOKKOS_INLINE_FUNCTION std::size_t n_particles() const
Gets the number of particles in the container.
Definition particles_container.hpp:449
MC::ParticlePositions position
Definition particles_container.hpp:85
ParticleAges ages
Definition particles_container.hpp:88
MC::ParticleStatus status
Definition particles_container.hpp:86
Definition model_kernel.hpp:55
Kokkos::View< value_type, Space > result_view_type
Definition model_kernel.hpp:60
Concept to check if a model type has uniform_weight
Definition traits.hpp:189
std::size_t c_league_size(std::size_t n_tot, std::size_t n_per_team) noexcept
Definition common.cpp:17
decltype(Kokkos::Experimental::create_scatter_view( kernelContribution())) ContributionView
Definition alias.hpp:162
gen_pool_type< Kokkos::DefaultExecutionSpace > pool_type
Definition alias.hpp:100
Kokkos::View< const double **, Kokkos::LayoutLeft, ComputeSpace, Kokkos::MemoryTraits< Kokkos::RandomAccess > > KernelConcentrationType
Definition alias.hpp:165
Definition kernels.hpp:16
constexpr bool enable_leave
Definition move_kernel.hpp:22
KernelInline::CycleReducer< Space >::result_view_type cycle_reducer_view_type
Definition kernels.hpp:19
constexpr bool enable_move
Definition move_kernel.hpp:25
Kokkos::View< std::size_t, Space > move_reducer_view_type
Definition kernels.hpp:21
Probes< AutoGenerated::probe_buffer_size > ProbeAutogeneratedBuffer
Definition probe.hpp:148
Definition contribution_kernel.hpp:9
Definition execinfo.hpp:12
Structure to store information about domain needed during MC cycle data is likely to change between e...
Definition domain.hpp:28
Use to count events that occurs during Monte-Carlo processing cycles.
Definition events.hpp:150
Definition model_kernel.hpp:124
CycleFunctor< Model > cycle_kernel_type
Definition kernels.hpp:27
cycle_kernel_type cycle_kernel
Definition kernels.hpp:36
ComputeSpace model_space
Definition kernels.hpp:32
MoveFunctor move_kernel_type
Definition kernels.hpp:28
bool f_multi_compartment
Definition kernels.hpp:45
move_kernel_type move_kernel
Definition kernels.hpp:37
auto get_host_reduction()
Definition kernels.hpp:78
void launch_move(const std::size_t n_particle) const
Definition kernels.hpp:122
KernelDispatchOptions m_options
Definition kernels.hpp:43
ComputeSpace move_space
Definition kernels.hpp:30
cycle_reducer_view_type< Space > cycle_reducer
Definition kernels.hpp:34
move_reducer_view_type< Space > move_reducer
Definition kernels.hpp:35
void launch_model(const std::size_t n_particle) const
Definition kernels.hpp:154
Model FModel
Definition kernels.hpp:25
ContributionFunctor< Model > contribution_kernel
Definition kernels.hpp:39
void update(const double d_t, MC::ParticlesContainer< Model > container, MC::DomainState< ComputeSpace > &&new_move)
Definition kernels.hpp:48
Definition move_kernel.hpp:115