4#ifndef IONIC_FITZHUGH_NAGUMO_H
5#define IONIC_FITZHUGH_NAGUMO_H
7#include "ionic_model.h"
24 static inline const std::string
label =
"FN";
40 constexpr bool required =
true;
56 virtual std::unique_ptr<IonicModelParameters>
58 return std::make_unique<Parameters>();
66 const cmType &cm)
override;
86 virtual void update_g(
const unsigned int zone_id,
const double dt,
94 const double I_sac)
const override;
97 virtual Array<double>
getj(
const unsigned int zone_id,
99 const double Ksac)
const override;
The CmMod class duplicates the data structures in the Fortran CMMOD module defined in COMU....
Definition CmMod.h:35
Model parameters class.
Definition ionic_fitzhugh_nagumo.h:37
FitzHugh-Nagumo ionic model.
Definition ionic_fitzhugh_nagumo.h:21
double alpha
[1].
Definition ionic_fitzhugh_nagumo.h:77
virtual void read_parameters(const IonicModelParameters ¶ms) override
Read model parameters from a parameter object.
Definition ionic_fitzhugh_nagumo.cpp:6
static const InitialStates initial_X
State variables.
Definition ionic_fitzhugh_nagumo.h:27
double c
[1].
Definition ionic_fitzhugh_nagumo.h:80
double a
[1].
Definition ionic_fitzhugh_nagumo.h:78
virtual unsigned int get_calcium_index() const override
Get the calcium proxy index.
Definition ionic_fitzhugh_nagumo.h:69
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_fitzhugh_nagumo.cpp:38
virtual void update_g(const unsigned int zone_id, const double dt, const Vector< double > &X, Vector< double > &Xg) const override
Definition ionic_fitzhugh_nagumo.h:86
virtual void distribute_parameters(const CmMod &cm_mod, const cmType &cm) override
Distribute model parameters to all parallel processes.
Definition ionic_fitzhugh_nagumo.cpp:15
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_fitzhugh_nagumo.cpp:25
FitzHughNagumo()
Constructor.
Definition ionic_fitzhugh_nagumo.h:50
static constexpr unsigned int calcium_index
Definition ionic_fitzhugh_nagumo.h:34
double b
[1].
Definition ionic_fitzhugh_nagumo.h:79
static const std::string label
Model label.
Definition ionic_fitzhugh_nagumo.h:24
static const InitialStates initial_Xg
Gating variables.
Definition ionic_fitzhugh_nagumo.h:30
virtual std::unique_ptr< IonicModelParameters > get_parameters() const override
Construct an instance of model parameters.
Definition ionic_fitzhugh_nagumo.h:57
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 Vector template class is used for storing int and double data.
Definition Vector.h:24
The cmType class stores data and defines methods used for mpi communication.
Definition CmMod.h:55