BioCMAMC-ST
domain.hpp
1#ifndef __MC_REACTORDOMAIN_HPP__
2#define __MC_REACTORDOMAIN_HPP__
3
4#include <Kokkos_Core.hpp>
5#include <cassert>
6#include <common/common.hpp>
7#include <cstddef>
8#include <cstdint>
9#include <mc/alias.hpp>
10#include <mc/traits.hpp>
11#include <span>
12
13namespace MC
14{
15
18 {
19 std::size_t index;
20 double flow;
21 double volume;
22 };
23
35
55 {
56 public:
57 using n_cells_view_type = Kokkos::View<uint64_t*, ComputeSpace>;
58 ReactorDomain(const ReactorDomain&) = delete;
60
65
69 ReactorDomain(ReactorDomain&& other) noexcept = default;
70
74 explicit ReactorDomain(std::span<double> volumes);
75
76 ReactorDomain(double total_volume, std::size_t size);
77
81 ~ReactorDomain() = default;
82
86 ReactorDomain& operator=(ReactorDomain&& other) noexcept;
87
88 void update(std::span<const double> newliquid_volume,
89 std::span<const std::size_t> neighors_flat,
90 std::span<const double> out_flows,
91 std::span<const double> proba_flat);
92
93 void set_leaving_flow(std::size_t i,
94 std::size_t i_flow,
95 double flow,
96 double volume) const;
97
98 void init_inner(std::size_t n_flows);
99
101
105 [[nodiscard]] size_t getNumberCompartments() const noexcept;
106
110 [[nodiscard]] double getTotalVolume() const noexcept;
111
115 template <class Archive>
116 void
117 save(Archive& ar) const
118 {
119
120 ar(id, size, _total_volume);
121 }
122
123 template <class Archive>
124 void
125 load(Archive& ar)
126 {
127 ar(id, size, _total_volume);
128 }
129
130 private:
131 double _total_volume = 0.;
132 size_t id = 0;
133 size_t size = 0;
135
139 void setVolumes(std::span<double const> volumes_liq);
140
144 void setLiquidNeighbors(std::size_t e1,
145 std::size_t e2,
146 std::span<const size_t> flat_data);
147 };
148
149 // inline NeighborsView<ComputeSpace, true> ReactorDomain::getNeighbors() const
150 // {
151 // return this->inner.neighbors;
152 // }
153
154 inline size_t
156 {
157 return size;
158 }
159
160 inline double
162 {
163 return this->_total_volume;
164 }
165
166 [[nodiscard]] inline DomainState<ComputeSpace, true>
168 {
169
170 return { inner.neighbors,
171 inner.diag_transition,
172 inner.cumulative_probability,
173 inner.leaving_flow,
174 inner.liquid_volume };
175 }
176
177} // namespace MC
178
179#endif //__MC_REACTORDOMAIN_HPP__
void update(std::span< const double > newliquid_volume, std::span< const std::size_t > neighors_flat, std::span< const double > out_flows, std::span< const double > proba_flat)
Definition domain.cpp:44
double _total_volume
Domain total volume.
Definition domain.hpp:131
DomainState< ComputeSpace, true > get_const_inner()
Definition domain.hpp:167
ReactorDomain & operator=(const ReactorDomain &)=delete
~ReactorDomain()=default
Default destructor.
Kokkos::View< uint64_t *, ComputeSpace > n_cells_view_type
Definition domain.hpp:57
void load(Archive &ar)
Definition domain.hpp:125
double getTotalVolume() const noexcept
Return total volume of domain.
Definition domain.hpp:161
ReactorDomain()
Default constructor.
Definition domain.cpp:31
void setLiquidNeighbors(std::size_t e1, std::size_t e2, std::span< const size_t > flat_data)
Update neigbors of compartments.
Definition domain.cpp:77
void init_inner(std::size_t n_flows)
Definition domain.cpp:123
size_t size
Number of compartment.
Definition domain.hpp:133
void save(Archive &ar) const
Return a const reference to neighbors.
Definition domain.hpp:117
void setVolumes(std::span< double const > volumes_liq)
Set volume of liquid and gas of each compartment.
Definition domain.cpp:14
void set_leaving_flow(std::size_t i, std::size_t i_flow, double flow, double volume) const
Definition domain.cpp:97
ReactorDomain(const ReactorDomain &)=delete
DomainState< ComputeSpace, false > inner
Definition domain.hpp:134
size_t getNumberCompartments() const noexcept
Return the number of compartment in the domain.
Definition domain.hpp:155
ReactorDomain(ReactorDomain &&other) noexcept=default
Move constructor.
Namespace that contains classes and structures related to Monte Carlo (MC) simulations.
Definition alias.hpp:16
std::conditional_t< is_const, Kokkos::View< const std::size_t **, Kokkos::LayoutRight, ExecSpace, Kokkos::MemoryTraits< Kokkos::RandomAccess > >, Kokkos::View< std::size_t **, Kokkos::LayoutRight, ExecSpace > > NeighborsView
Definition alias.hpp:206
std::conditional_t< is_const, Kokkos::View< const double *, ExecSpace, Kokkos::MemoryTraits< Kokkos::RandomAccess > >, Kokkos::View< double *, ExecSpace > > VolumeView
Definition alias.hpp:173
std::conditional_t< is_const, Kokkos::View< const LeavingFlow *, Kokkos::SharedHostPinnedSpace >, Kokkos::View< LeavingFlow *, Kokkos::SharedHostPinnedSpace > > LeavingFlowView
Definition alias.hpp:190
std::conditional_t< is_const, Kokkos::View< const double **, Kokkos::LayoutRight, ExecSpace, Kokkos::MemoryTraits< Kokkos::RandomAccess > >, Kokkos::View< double **, Kokkos::LayoutRight, ExecSpace > > CumulativeProbabilityView
Definition alias.hpp:197
std::conditional_t< is_const, Kokkos::View< const double *, Kokkos::LayoutLeft, ExecSpace, Kokkos::MemoryTraits< Kokkos::RandomAccess > >, Kokkos::View< double *, Kokkos::LayoutLeft, ExecSpace > > DiagonalView
Definition alias.hpp:181
Structure to store information about domain needed during MC cycle data is likely to change between e...
Definition domain.hpp:28
VolumeView< ExecSpace, is_const > liquid_volume
Definition domain.hpp:33
MC::NeighborsView< ExecSpace, is_const > neighbors
Definition domain.hpp:29
DiagonalView< ExecSpace, is_const > diag_transition
Definition domain.hpp:30
LeavingFlowView< is_const > leaving_flow
Definition domain.hpp:32
CumulativeProbabilityView< ExecSpace, is_const > cumulative_probability
Definition domain.hpp:31
Store position and value of volumic flow at outlet.
Definition domain.hpp:18
std::size_t index
Definition domain.hpp:19
double volume
Definition domain.hpp:21
double flow
Definition domain.hpp:20