34#ifndef SVZERODSOLVER_SIMULATIONPARAMETERS_HPP_
35#define SVZERODSOLVER_SIMULATIONPARAMETERS_HPP_
38#include <nlohmann/json.hpp>
96 JsonWrapper(
const nlohmann::json& json,
const std::string& component,
97 const std::string& name_str,
const int&
id)
98 : nlohmann::json(json[component][id]),
111 if (!this->contains(key)) {
112 if (this->contains(name_str)) {
113 const std::string name = this->at(name_str);
114 throw std::runtime_error(
"Key " + std::string(key) +
115 " not found in element " + name +
116 " of component " + component);
118 throw std::runtime_error(
119 "Key " + std::string(key) +
" not found in element number " +
120 std::to_string(block_id) +
" of component " + component);
123 return this->at(key);
127 using nlohmann::json::contains;
128 using nlohmann::json::value;
129 using nlohmann::json::operator[];
132 std::string component;
133 std::string name_str;
152 const std::string& block_type,
const std::string_view& name,
153 bool internal =
false,
bool periodic =
true);
200 std::vector<std::tuple<std::string, std::string>>& connections,
201 const nlohmann::json& config,
const std::string& component,
202 std::map<int, std::string>& vessel_id_map);
217 std::vector<std::tuple<std::string, std::string>>& connections,
218 const nlohmann::json& config,
const std::string& component,
219 std::map<int, std::string>& vessel_id_map,
220 std::map<std::string, std::string>& bc_type_map);
233 const std::string& component,
234 std::map<std::string, std::string>& bc_type_map,
235 std::vector<std::string>& closed_loop_bcs);
248 std::vector<std::tuple<std::string, std::string>>& connections,
249 const nlohmann::json& config,
const std::string& component,
250 std::map<int, std::string>& vessel_id_map);
264 std::vector<std::tuple<std::string, std::string>>& connections,
265 const nlohmann::json& config,
const std::string& component,
266 std::vector<std::string>& closed_loop_bcs);
278 std::vector<std::tuple<std::string, std::string>>& connections,
279 const nlohmann::json& config,
const std::string& component);
291 std::vector<std::tuple<std::string, std::string>>& connections,
292 const nlohmann::json& config,
const std::string& component);
void create_chambers(Model &model, std::vector< std::tuple< std::string, std::string > > &connections, const nlohmann::json &config, const std::string &component)
Handle the creation of chambers.
Definition SimulationParameters.cpp:567
void create_junctions(Model &model, std::vector< std::tuple< std::string, std::string > > &connections, const nlohmann::json &config, const std::string &component, std::map< int, std::string > &vessel_id_map)
Handle the creation of junctions and their connections.
Definition SimulationParameters.cpp:451
void create_boundary_conditions(Model &model, const nlohmann::json &config, const std::string &component, std::map< std::string, std::string > &bc_type_map, std::vector< std::string > &closed_loop_bcs)
Handle the creation of boundary condition blocks.
Definition SimulationParameters.cpp:331
void create_valves(Model &model, std::vector< std::tuple< std::string, std::string > > &connections, const nlohmann::json &config, const std::string &component)
Handle the creation of valves and their associated connections.
Definition SimulationParameters.cpp:549
State load_initial_condition(const nlohmann::json &config, Model &model)
Load initial conditions from a JSON configuration.
Definition SimulationParameters.cpp:580
void create_vessels(Model &model, std::vector< std::tuple< std::string, std::string > > &connections, const nlohmann::json &config, const std::string &component, std::map< int, std::string > &vessel_id_map)
Handle the creation of vessel blocks and connections with boundary conditions.
Definition SimulationParameters.cpp:296
void create_closed_loop(Model &model, std::vector< std::tuple< std::string, std::string > > &connections, const nlohmann::json &config, const std::string &component, std::vector< std::string > &closed_loop_bcs)
Handle the creation of closed-loop blocks and associated connections.
Definition SimulationParameters.cpp:493
void load_simulation_model(const nlohmann::json &config, Model &model)
Load the 0D block in the model from a configuration.
Definition SimulationParameters.cpp:222
SimulationParameters load_simulation_params(const nlohmann::json &config)
Load the simulation parameters from a JSON configuration.
Definition SimulationParameters.cpp:179
int generate_block(Model &model, const nlohmann::json &block_params_json, const std::string &block_type, const std::string_view &name, bool internal=false, bool periodic=true)
Generate a new block and add its parameters to the model.
Definition SimulationParameters.cpp:72
void create_external_coupling(Model &model, std::vector< std::tuple< std::string, std::string > > &connections, const nlohmann::json &config, const std::string &component, std::map< int, std::string > &vessel_id_map, std::map< std::string, std::string > &bc_type_map)
Handle the creation of external coupling blocks and connections with other blocks.
Definition SimulationParameters.cpp:366
void validate_input(const nlohmann::json &config)
Check that the JSON configuration has the required inputs.
Definition SimulationParameters.cpp:170
Wrapper class for nlohmann:json with error checking.
Definition SimulationParameters.h:85
const nlohmann::json & operator[](const char *key) const
Wrap error check around key retrieval (throws detailed error if key doesn't exist)
Definition SimulationParameters.h:110
JsonWrapper(const nlohmann::json &json, const std::string &component, const std::string &name_str, const int &id)
Wrap around JSON configuration with detailed error message in case key is not found in configuration.
Definition SimulationParameters.h:96
Model of 0D elements.
Definition Model.h:75
State of the system.
Definition State.h:46
Simulation parameters.
Definition SimulationParameters.h:50
bool sim_coupled
Running 0D simulation coupled with external solver.
Definition SimulationParameters.h:78
int sim_nliter
Definition SimulationParameters.h:66
bool output_all_cycles
Output all cardiac cycles.
Definition SimulationParameters.h:76
int sim_pts_per_cycle
Number of time steps per cardiac cycle.
Definition SimulationParameters.h:57
int sim_num_time_steps
Total number of time steps.
Definition SimulationParameters.h:65
double sim_external_step_size
Definition SimulationParameters.h:80
double sim_time_step_size
Simulation time step size.
Definition SimulationParameters.h:53
int sim_num_cycles
Number of cardiac cycles to simulate.
Definition SimulationParameters.h:56
bool output_mean_only
Output only the mean value.
Definition SimulationParameters.h:74
bool sim_steady_initial
Start from steady solution.
Definition SimulationParameters.h:71
int output_interval
Interval of writing output.
Definition SimulationParameters.h:69
bool output_variable_based
Output variable based instead of vessel based.
Definition SimulationParameters.h:72
double sim_abs_tol
Absolute tolerance for simulation.
Definition SimulationParameters.h:54
bool output_derivative
Output derivatives.
Definition SimulationParameters.h:75
double sim_cycle_to_cycle_error
Cycle-to-cycle error.
Definition SimulationParameters.h:64
bool use_cycle_to_cycle_error
Definition SimulationParameters.h:58
double sim_rho_infty
Spectral radius of generalized-alpha.
Definition SimulationParameters.h:68