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>
19 template <
typename Space>
22 template <
typename Space>
25 template <
typename Space, ModelType Model>
struct CycleFunctors
56 const bool enable_leave = new_move.leaving_flow.size() != 0;
83 = Kokkos::create_mirror_view_and_copy(HostSpace(),
cycle_reducer)();
85 const auto host_out_counter
86 = Kokkos::create_mirror_view_and_copy(HostSpace(),
move_reducer)();
88 return std::tuple(host_red, host_out_counter);
104 std::move(_concentrations),
108 options.m_p_p_team_leave,
117 options.m_p_p_team_contribs, _contribs_scatter, container),
129 const auto npt =
m_options.m_p_p_team_move;
130 if (n_particle <= npt)
133 throw std::runtime_error(
"Nparticle<n per team");
140 static_cast<int>(league_size),
144 cycle_policy.set_scratch_size(0,
145 Kokkos::PerTeam(
sizeof(
float) * npt * 2));
147 Kokkos ::parallel_for(
"cycle_move", cycle_policy,
move_kernel);
153 const auto _policy_leave = Kokkos::RangePolicy<KernelInline::TagLeave>(
155 Kokkos ::parallel_reduce(
163 if (n_particle <=
m_options.m_p_p_team_model)
166 throw std::runtime_error(
"Nparticle<n per team");
169 std::size_t league_size
172 const auto cycle_policy
174 static_cast<int>(league_size),
178 Kokkos::parallel_reduce(
193 if (n_particle <=
m_options.m_p_p_team_contribs)
196 throw std::runtime_error(
"Nparticle<n per team");
202 "ModelType:Constapply_weight()");
207 const auto policy_contribs
208 = Kokkos::TeamPolicy<typename ContributionFunctor<Model>::Tag3D>(
209 model_space, league_size, Kokkos::AUTO(), Kokkos::AUTO());
210 Kokkos::parallel_for(
216 = Kokkos::TeamPolicy<typename ContributionFunctor<Model>::Tag0D>(
217 model_space, league_size, Kokkos::AUTO(), Kokkos::AUTO());
218 policy_contribs.set_scratch_size(
219 0, Kokkos::PerTeam(
sizeof(
float) * Model::n_c));
220 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:201
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:17
constexpr bool enable_leave
Definition move_kernel.hpp:22
KernelInline::CycleReducer< Space >::result_view_type cycle_reducer_view_type
Definition kernels.hpp:20
constexpr bool enable_move
Definition move_kernel.hpp:25
Kokkos::View< std::size_t, Space > move_reducer_view_type
Definition kernels.hpp:22
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:28
cycle_kernel_type cycle_kernel
Definition kernels.hpp:37
ComputeSpace model_space
Definition kernels.hpp:33
MoveFunctor move_kernel_type
Definition kernels.hpp:29
bool f_multi_compartment
Definition kernels.hpp:46
move_kernel_type move_kernel
Definition kernels.hpp:38
auto get_host_reduction()
Definition kernels.hpp:79
void launch_move(const std::size_t n_particle) const
Definition kernels.hpp:123
KernelDispatchOptions m_options
Definition kernels.hpp:44
ComputeSpace move_space
Definition kernels.hpp:31
cycle_reducer_view_type< Space > cycle_reducer
Definition kernels.hpp:35
move_reducer_view_type< Space > move_reducer
Definition kernels.hpp:36
void launch_model(const std::size_t n_particle) const
Definition kernels.hpp:160
Model FModel
Definition kernels.hpp:26
ContributionFunctor< Model > contribution_kernel
Definition kernels.hpp:40
void update(const double d_t, MC::ParticlesContainer< Model > container, MC::DomainState< ComputeSpace > &&new_move)
Definition kernels.hpp:49
Definition move_kernel.hpp:115