4#ifndef IONIC_BUENO_OROVIO_H
5#define IONIC_BUENO_OROVIO_H
7#include "ionic_model.h"
22 static inline const std::string
label =
"BO";
26 {
"u", -84.0}, {
"v", 1.0}, {
"w", 1.0}, {
"s", 0.0}};
39 constexpr bool required =
true;
79 virtual std::unique_ptr<IonicModelParameters>
81 return std::make_unique<Parameters>();
89 const cmType &cm)
override;
141 virtual void update_g(
const unsigned int zone_id,
const double dt,
149 const double I_sac)
const override;
152 virtual Array<double>
getj(
const unsigned int zone_id,
154 const double Ksac)
const override;
157 inline double step(
const double r)
const {
return r < 0.0 ? 0.0 : 1.0; }
160 inline double delta(
const double r)
const {
161 return utils::is_zero(r) ? 1.0 : 0.0;
Model parameters class.
Definition ionic_bueno_orovio.h:36
Bueno-Orovio ionic model.
Definition ionic_bueno_orovio.h:19
static constexpr unsigned int calcium_index
Definition ionic_bueno_orovio.h:33
ModelParam theta_v
[1].
Definition ionic_bueno_orovio.h:110
ModelParam tau_so2
[1/s].
Definition ionic_bueno_orovio.h:126
virtual void read_parameters(const IonicModelParameters ¶ms) override
Read model parameters from a parameter object.
Definition ionic_bueno_orovio.cpp:6
ModelParam theta_w
[1].
Definition ionic_bueno_orovio.h:111
ModelParam u_so
[1].
Definition ionic_bueno_orovio.h:128
static const InitialStates initial_X
State variables.
Definition ionic_bueno_orovio.h:25
ModelParam tau_s2
[1/s].
Definition ionic_bueno_orovio.h:130
ModelParam tau_s1
[1/s].
Definition ionic_bueno_orovio.h:129
ModelParam u_u
[1].
Definition ionic_bueno_orovio.h:109
virtual unsigned int get_calcium_index() const override
Get the calcium proxy index.
Definition ionic_bueno_orovio.h:92
virtual void update_g(const unsigned int zone_id, const double dt, const Vector< double > &X, Vector< double > &Xg) const override
Definition ionic_bueno_orovio.h:141
ModelParam tau_winf
[1/s].
Definition ionic_bueno_orovio.h:134
ModelParam taum_w1
[1/s].
Definition ionic_bueno_orovio.h:117
ModelParam taum_w2
[1/s].
Definition ionic_bueno_orovio.h:118
ModelParam tau_o2
[1/s].
Definition ionic_bueno_orovio.h:124
ModelParam tau_so1
[1/s].
Definition ionic_bueno_orovio.h:125
virtual Vector< double > getf(const unsigned int zone_id, const Vector< double > &X, const Vector< double > &Xg, const double I_stim, const double I_sac) const override
Model right-hand side.
Definition ionic_bueno_orovio.cpp:72
ModelParam k_so
[1].
Definition ionic_bueno_orovio.h:127
double delta(const double r) const
Delta function.
Definition ionic_bueno_orovio.h:160
ModelParam taup_w
[1/s].
Definition ionic_bueno_orovio.h:121
virtual Array< double > getj(const unsigned int zone_id, const Vector< double > &X, const Vector< double > &Xg, const double Ksac) const override
Model jacobian.
Definition ionic_bueno_orovio.cpp:119
ModelParam taum_v1
[1/s].
Definition ionic_bueno_orovio.h:114
virtual std::unique_ptr< IonicModelParameters > get_parameters() const override
Construct an instance of model parameters.
Definition ionic_bueno_orovio.h:80
ModelParam u_o
[1].
Definition ionic_bueno_orovio.h:108
static const InitialStates initial_Xg
Gating variables.
Definition ionic_bueno_orovio.h:29
ModelParam tau_si
[1/s].
Definition ionic_bueno_orovio.h:133
ModelParam theta_o
[1].
Definition ionic_bueno_orovio.h:113
static const std::string label
Model label.
Definition ionic_bueno_orovio.h:22
ModelParam tau_o1
[1/s].
Definition ionic_bueno_orovio.h:123
ModelParam taup_v
[1/s].
Definition ionic_bueno_orovio.h:116
virtual void distribute_parameters(const CmMod &cm_mod, const cmType &cm) override
Distribute model parameters to all parallel processes.
Definition ionic_bueno_orovio.cpp:39
ModelParam taum_v2
[1/s].
Definition ionic_bueno_orovio.h:115
ModelParam km_w
[1].
Definition ionic_bueno_orovio.h:119
double step(const double r) const
Step function.
Definition ionic_bueno_orovio.h:157
ModelParam um_w
[1].
Definition ionic_bueno_orovio.h:120
ModelParam tau_fi
[1/s].
Definition ionic_bueno_orovio.h:122
ModelParam k_s
[1].
Definition ionic_bueno_orovio.h:131
ModelParam ws_inf
[1].
Definition ionic_bueno_orovio.h:135
ModelParam thetam_v
[1].
Definition ionic_bueno_orovio.h:112
BuenoOrovio()
Constructor.
Definition ionic_bueno_orovio.h:73
ModelParam u_s
[1].
Definition ionic_bueno_orovio.h:132
The CmMod class duplicates the data structures in the Fortran CMMOD module defined in COMU....
Definition CmMod.h:35
Abstract ionic model class.
Definition ionic_model.h:127
std::vector< std::pair< std::string, double > > InitialStates
Definition ionic_model.h:133
Initial conditions parameters for a generic ionic model.
Definition Parameters.h:1242
void add_parameter(const std::string &label, double default_value, bool required)
Add a new parameter to this object.
Definition Parameters.h:1290
The cmType class stores data and defines methods used for mpi communication.
Definition CmMod.h:55