1#ifndef __BIO__EXT_MODULE_DEF__
2#define __BIO__EXT_MODULE_DEF__
4#include "Kokkos_Core_fwd.hpp"
6#ifdef DECLARE_EXPORT_UDF
7# include <dynlib/dyn_module.hpp>
8# include <dynlib/dynlib.hpp>
11#include <Kokkos_Core.hpp>
12#include <mc/prng/prng.hpp>
13#include <mc/traits.hpp>
14#include <models/udf_model.hpp>
46 Kokkos::DefaultHostExecutionSpace& ep, std::size_t n);
59 static std::vector<std::string_view> (*
names)();
61 static std::vector<std::size_t> (*
get_number)();
65#ifdef DECLARE_EXPORT_UDF
69 [[nodiscard]]
static std::shared_ptr<DynamicLibrary>
70 init_lib(std::string_view path);
76#ifdef DECLARE_EXPORT_UDF
94using get_number_udf_ptr
102 MODULE_ITEM(init_udf)
103 MODULE_ITEM(update_udf)
104 MODULE_ITEM(division_udf)
105 MODULE_ITEM(mass_udf)
106 MODULE_ITEM(names_udf)
107 MODULE_ITEM(get_number_udf)
108 MODULE_ITEM(set_nvar_udf)
109 MODULE_ITEM(get_bounds_udf)
110 MODULE_ITEM(get_config_udf)
Kokkos::Subview< KernelConcentrationType, int, decltype(Kokkos::ALL)> LocalConcentration
Definition alias.hpp:105
Status
Definition alias.hpp:58
gen_pool_type< Kokkos::DefaultExecutionSpace > pool_type
Definition alias.hpp:39
Kokkos::View< F **, Kokkos::LayoutRight > DynParticlesModel
Definition alias.hpp:21
Unsafe namespace to handle UDF (User-defined function) via dynamic library loading.
Definition udf_includes.hpp:21
Kokkos::View< float ** > Config
Definition udf_model.hpp:17
MC::DynParticlesModel< FloatType > SelfParticle
Definition udf_model.hpp:16
Static class to access to low-level configuration to load dynamic library.
Definition udf_includes.hpp:27
static std::vector< std::string_view >(* names)()
Definition udf_includes.hpp:59
static MC::ContribIndexBounds(* get_bounds_udf)()
Definition udf_includes.hpp:43
static Models::UdfModel::Config(* get_config_udf)(Kokkos::DefaultHostExecutionSpace &ep, std::size_t n)
Definition udf_includes.hpp:45
static void(* init_udf)(const MC::pool_type &random_pool, std::size_t idx, const Models::UdfModel::SelfParticle &arr, const Models::UdfModel::Config &config)
Definition udf_includes.hpp:30
static void(* division_udf)(const MC::pool_type &random_pool, std::size_t idx, std::size_t idx2, const MC::DynParticlesModel< float > &arr, const MC::DynParticlesModel< float > &buffer_arr)
Definition udf_includes.hpp:48
static std::size_t(* set_nvar_udf)()
Definition udf_includes.hpp:28
static std::vector< std::size_t >(* get_number)()
Definition udf_includes.hpp:61
static MC::Status(* update_udf)(const MC::pool_type &random_pool, float d_t, std::size_t idx, const Models::UdfModel::SelfParticle &arr, const MC::LocalConcentration &c)
Definition udf_includes.hpp:36
static double(* mass)(std::size_t idx, const MC::DynParticlesModel< float > &arr)
Definition udf_includes.hpp:55