BioCMAMC-ST
api.hpp
1#ifndef __BIOMC_API_HPP__
2#define __BIOMC_API_HPP__
3
4#include "common/logger.hpp"
5#include <api/results.hpp>
6#include <common/execinfo.hpp>
7#include <core/case_data.hpp>
8#include <core/scalar_factory.hpp>
9#include <core/simulation_parameters.hpp>
10#include <cstdlib>
11#include <memory>
12#include <optional>
13#include <simulation/feed_descriptor.hpp>
14#include <simulation/mass_transfer.hpp>
15#include <span>
16#include <string_view>
17#include <utility>
18
23namespace Api
24{
25 constexpr std::array<int, 3>
27 {
28 return { _BIOMC_VERSION_MAJOR, _BIOMC_VERSION_MINOR, _BIOMC_VERSION_DEV };
29 }
30
31 void finalise();
32
49 {
50 public:
68
78 static std::optional<std::unique_ptr<SimulationInstance> >
79 init(int argc,
80 char** argv,
81 std::optional<std::size_t> run_id = std::nullopt) noexcept;
82
91
99 ApiResult apply(bool to_load) noexcept;
100
106 ApiResult apply() noexcept;
107
114 ApiResult apply_load() noexcept;
115
123 register_parameters(Core::UserControlParameters&& params) noexcept;
124
131 bool register_result_path(std::string_view path);
132
134 register_initial_condition(Core::ScalarFactory::ScalarVariant&& type);
135 ApiResult register_initialiser_file_path(std::string_view path);
143 ApiResult register_cma_path(std::string_view path);
144
151 bool register_serde(std::string_view path);
152
159 ApiResult register_model_name(std::string_view path);
160
161 ApiResult set_feed(Simulation::Feed::FeedDescriptor feed_variant,
162 Phase phase = Phase::Liquid);
163
164 ApiResult set_feed_constant(double _flow,
165 double _concentration,
166 std::size_t _species,
167 std::size_t _position,
168 bool gas = false,
169 bool fed_batch = false);
170
172 double _concentration,
173 std::size_t _species,
174 std::size_t input_position,
175 std::size_t output_position,
176 bool gas = false);
177
178 ApiResult set_mtr(Simulation::MassTransfer::Type::MtrTypeVariant&& variant);
179
180 void set_auto_mtr();
181
182 // /**
183 // * @brief Configure feed constants for the simulation.
184 // *
185 // * @param _flow A constant flow value.
186 // * @param concentrations A span of concentrations values.
187 // * @param _position A span of position indices.
188 // * @param _species A span of species indices.
189 // * @param gas Flag indicating whether the feed is gas-phase.
190 // * @return True if the feed was successfully configured; false otherwise.
191 // */
192 // [[deprecated]]bool set_feed_constant(double _flow,
193 // std::span<double> _concentration,
194 // std::span<std::size_t> _position,
195 // std::span<std::size_t> _species,
196 // bool gas = false,
197 // bool fed_batch = false);
198
199 // [[deprecated]]bool set_feed_constant_from_position(double _flow,
200 // std::span<double> _concentration,
201 // std::span<std::size_t> _position,
202 // std::span<std::size_t> _species,
203 // std::optional<std::vector<std::size_t>>
204 // _output_position, bool gas = false,
205 // bool fed_batch = false);
206
207 // [[deprecated]]bool set_feed_constant_from_rvalue(double _f,
208 // std::vector<double>&& _target,
209 // std::vector<std::size_t>&& _position,
210 // std::vector<std::size_t>&& _species,
211 // bool gas = false,
212 // bool fed_batch = false);
213
215 register_scalar_initiazer(Core::ScalarFactory::ScalarVariant&& var);
216
222 [[nodiscard]] int get_id() const;
223
224 [[nodiscard]] const ExecInfo& get_exec_info() const;
225
231 ApiResult exec() noexcept;
232
233 void
234 set_logger(std::shared_ptr<IO::Logger> _logger)
235 {
236
237 logger = std::move(_logger);
238 }
239
240 [[nodiscard]] auto&
242 {
243 return logger;
244 }
245
246 private:
247 int id{};
248
257 SimulationInstance(int argc,
258 char** argv,
259 std::optional<std::size_t> run_id);
260
261 std::shared_ptr<IO::Logger> logger;
262
263 std::optional<Core::ScalarFactory::ScalarVariant> scalar_initializer_variant
264 = std::nullopt;
267 bool loaded = false;
268 bool applied = false;
269 bool registered = false;
270 std::optional<Simulation::Feed::SimulationFeed> feed
271 = std::nullopt;
272 std::optional<Simulation::MassTransfer::Type::MtrTypeVariant> mtr_type
273 = std::nullopt;
274
276 };
277
278} // namespace Api
279#endif
Api This namespace contains classes and functions related to the simulation API.
Definition api.hpp:24
constexpr std::array< int, 3 > get_version()
Definition api.hpp:26
void finalise()
Definition api.cpp:66
Core component to perform simulation.
Definition data_exporter.hpp:19
Definition impl_post_process.hpp:11
Namespace that contains classes and structures related to simulation handling.
Definition host_specific.hpp:14
Definition results.hpp:8
ApiResult register_model_name(std::string_view path)
Register the model name for the simulation.
Definition api.cpp:398
SimulationInstance(SimulationInstance &&)=default
Defaulted move constructor for efficient resource transfer.
std::optional< Core::ScalarFactory::ScalarVariant > scalar_initializer_variant
Definition api.hpp:264
bool register_result_path(std::string_view path)
Register a result output path.
Definition api.cpp:344
bool registered
Flag indicating if resources are registered.
Definition api.hpp:269
const ExecInfo & get_exec_info() const
Definition api.cpp:405
ApiResult exec() noexcept
Execute the simulation.
Definition api.cpp:163
bool register_serde(std::string_view path)
Register a serialization/deserialization (serde) path.
Definition api.cpp:390
ApiResult set_feed(Simulation::Feed::FeedDescriptor feed_variant, Phase phase=Phase::Liquid)
Definition api.cpp:82
void set_logger(std::shared_ptr< IO::Logger > _logger)
Definition api.hpp:234
ApiResult set_feed_constant(double _flow, double _concentration, std::size_t _species, std::size_t _position, bool gas=false, bool fed_batch=false)
Definition api.cpp:96
std::optional< Simulation::MassTransfer::Type::MtrTypeVariant > mtr_type
Definition api.hpp:273
void set_auto_mtr()
Definition api.cpp:236
SimulationInstance(const SimulationInstance &)=delete
Deleted copy constructor to prevent copying.
ApiResult register_initial_condition(Core::ScalarFactory::ScalarVariant &&type)
Definition api.cpp:382
auto & get_logger() const
Definition api.hpp:241
Core::CaseData _data
Case data for the simulation.
Definition api.hpp:265
bool auto_mtr
Definition api.hpp:275
SimulationInstance & operator=(SimulationInstance &&)=default
Defaulted move assignment operator for efficient resource transfer.
std::shared_ptr< IO::Logger > logger
Definition api.hpp:261
int get_id() const
Retrieve the simulation instance's unique identifier.
Definition api.cpp:76
static std::optional< std::unique_ptr< SimulationInstance > > init(int argc, char **argv, std::optional< std::size_t > run_id=std::nullopt) noexcept
Initialize a simulation instance.
Definition api.cpp:148
ApiResult register_cma_path(std::string_view path)
Register a path for CMA data.
Definition api.cpp:360
ApiResult apply_load() noexcept
Load ad apply the simulation configuration and prepare for execution based on file.
Definition api.cpp:199
ApiResult set_mtr(Simulation::MassTransfer::Type::MtrTypeVariant &&variant)
Definition api.cpp:226
ApiResult register_parameters(Core::UserControlParameters &&params) noexcept
Register user control parameters for the simulation.
Definition api.cpp:335
bool applied
Flag indicating if the configuration is applied.
Definition api.hpp:268
~SimulationInstance()
Default destructor.
Definition api.cpp:141
std::optional< Simulation::Feed::SimulationFeed > feed
Optional feed configuration.
Definition api.hpp:271
SimulationInstance & operator=(const SimulationInstance &)=delete
Deleted copy assignment operator to prevent copying.
Core::UserControlParameters params
User-defined control parameters.
Definition api.hpp:266
ApiResult apply() noexcept
Apply the simulation configuration and prepare for execution.
Definition api.cpp:242
ApiResult set_feed_constant_different_output(double _flow, double _concentration, std::size_t _species, std::size_t input_position, std::size_t output_position, bool gas=false)
Definition api.cpp:113
bool loaded
Flag indicating if the instance is loaded.
Definition api.hpp:267
ApiResult register_initialiser_file_path(std::string_view path)
Definition api.cpp:353
ApiResult register_scalar_initiazer(Core::ScalarFactory::ScalarVariant &&var)
Configure feed constants for the simulation.
Definition api.cpp:302
SimulationInstance()=delete
Default constructor.
Holds the data required to execute a simulation case.
Definition case_data.hpp:39
A structure to hold user-defined control parameters for simulation settings.
Definition simulation_parameters.hpp:24
Definition execinfo.hpp:12