BioCMAMC-ST
serde.hpp
1
2
3#ifndef __CORE__SERDE_HPP__
4#define __CORE__SERDE_HPP__
5#include <core/global_initaliser.hpp>
6
7#include <core/case_data.hpp>
8#include <string_view>
9#ifdef USE_CEAREAL
10namespace SerDe
11{
12 void save_simulation(const Core::CaseData& case_data);
13 bool load_simulation(Core::GlobalInitialiser& gi,
14 Core::CaseData& case_data,
15 std::string_view ser_filename);
16} // namespace SerDe
17
18#endif // USE_CEAREAL
19
20#ifdef USE_CEAREAL
21# include <cereal/archives/binary.hpp>
22// template <typename T = void>
23// std::enable_if_t<AutoGenerated::FlagCompileTime::use_cereal_serde, T>
24// do_serde(Core::CaseData& case_data)
25// {
26// std::cout << "Serialization..." << std::endl;
27// SerDe::save_simulation(case_data);
28// }
29template <typename T = void>
30 requires AutoGenerated::FlagCompileTime::use_cereal_serde
31void do_serde(Core::CaseData& case_data)
32{
33 std::cout << "Serialization..." << std::endl;
34 SerDe::save_simulation(case_data);
35}
36
37template <typename T = void>
38 requires AutoGenerated::FlagCompileTime::use_cereal_serde
39std::optional<Core::CaseData> impl_load(const ExecInfo& exec,
40 const Core::UserControlParameters&& params,
41 std::optional<Simulation::Feed::SimulationFeed> feed)
42{
43 Core::CaseData case_data;
44 case_data.exec_info = exec;
45 // if (exec.n_rank > 1)
46 // {
47 // throw std::runtime_error("Serde for MPI Not implemented yet");
48 // }
49
50 Core::GlobalInitialiser gi(exec, params);
51 auto transition = gi.init_transitionner();
52 if (!transition.has_value())
53 {
54 return std::nullopt;
55 }
56
57 case_data.transitioner = std::move(*transition);
58 gi.init_feed(std::move(feed));
59 try
60 {
61 if (!params.serde_file.has_value())
62 {
63 return std::nullopt;
64 }
65 std::string serde_filename = *params.serde_file + std::to_string(exec.current_rank) + ".raw";
66 std::cout << serde_filename << std::endl;
67 const bool ok_init = SerDe::load_simulation(gi, case_data, serde_filename);
68
69 if (!gi.check_init_terminate() || !ok_init)
70 {
71 return std::nullopt;
72 }
73 }
74 catch (std::exception& e)
75 {
76 auto err = "CORE::load::load_simulation:" + std::string(e.what());
77 throw std::runtime_error(err);
78 }
79
80 case_data.params = gi.get_parameters();
81 // TODO: Check integreity between transitionner and read value (transitionner and simulation tpf
82 // + n_species)
83
84 return case_data;
85}
86
87#endif
88
89template <typename T = void>
90 requires(!AutoGenerated::FlagCompileTime::use_cereal_serde)
91void do_serde(Core::CaseData& /*arg*/)
92{
93 // NOP
94}
95
96template <typename T = void>
97 requires(!AutoGenerated::FlagCompileTime::use_cereal_serde)
98[[maybe_unused]] std::optional<Core::CaseData>
99impl_load([[maybe_unused]] const ExecInfo& exec,
100 [[maybe_unused]] const Core::UserControlParameters&& params,
101 [[maybe_unused]] std::optional<Simulation::Feed::SimulationFeed> feed)
102{
103 return std::nullopt;
104}
105
106#endif
A class responsible for initializing various components of a simulation framework.
Definition global_initaliser.hpp:36
Holds the data required to execute a simulation case.
Definition case_data.hpp:28
ExecInfo exec_info
Information about the execution environment.
Definition case_data.hpp:61
SimulationParameters params
Parameters that configure the simulation.
Definition case_data.hpp:43
std::unique_ptr< CmaUtils::FlowMapTransitionner > transitioner
Unique pointer to the flow map transitioner.
Definition case_data.hpp:52
A structure to hold user-defined control parameters for simulation settings.
Definition simulation_parameters.hpp:24
Definition execinfo.hpp:12