#include <HeartConfigRelatedCellFactory.hpp>
Inherits AbstractCardiacCellFactory< SPACE_DIM >.
Public Member Functions | |
HeartConfigRelatedCellFactory () | |
~HeartConfigRelatedCellFactory () | |
AbstractCardiacCellInterface * | CreateCellWithIntracellularStimulus (boost::shared_ptr< AbstractStimulusFunction > intracellularStimulus, unsigned nodeIndex) |
AbstractCardiacCellInterface * | CreateCardiacCellForTissueNode (Node< SPACE_DIM > *pNode) |
void | FillInCellularTransmuralAreas () |
void | SetCellParameters (AbstractCardiacCellInterface *pCell, unsigned nodeIndex) |
void | SetCellIntracellularStimulus (AbstractCardiacCellInterface *pCell, unsigned nodeIndex) |
template<> | |
void | FillInCellularTransmuralAreas () |
Private Member Functions | |
void | PreconvertCellmlFiles () |
DynamicCellModelLoaderPtr | LoadDynamicModel (const cp::ionic_model_selection_type &rModel, bool isCollective) |
Private Attributes | |
cp::ionic_model_selection_type | mDefaultIonicModel |
std::vector< boost::shared_ptr < AbstractChasteRegion < SPACE_DIM > > > | mIonicModelRegions |
std::vector < cp::ionic_model_selection_type > | mIonicModelsDefined |
std::vector< boost::shared_ptr < AbstractChasteRegion < SPACE_DIM > > > | mStimulatedAreas |
std::vector< boost::shared_ptr < AbstractStimulusFunction > > | mStimuliApplied |
std::vector< boost::shared_ptr < AbstractChasteRegion < SPACE_DIM > > > | mCellHeterogeneityAreas |
std::vector< double > | mScaleFactorGks |
std::vector< double > | mScaleFactorIto |
std::vector< double > | mScaleFactorGkr |
std::vector< std::map < std::string, double > > | mParameterSettings |
This is a cardiac cell factory which uses the settings from HeartConfig to set up the cells.
It thus supports such features as heterogeneities (in both the type of cell, and for some cells, cell model parameters), and the ability to dynamically convert CellML files into C++ code, compile this, and load the resulting model.
Definition at line 96 of file HeartConfigRelatedCellFactory.hpp.
HeartConfigRelatedCellFactory< SPACE_DIM >::HeartConfigRelatedCellFactory | ( | ) | [inline] |
Constructor reads settings from the configuration file.
Definition at line 50 of file HeartConfigRelatedCellFactory.cpp.
References EXCEPTION, HeartConfig::GetCellHeterogeneities(), HeartConfig::GetIonicModelRegions(), HeartConfig::GetStimuli(), HeartConfig::Instance(), HeartConfig::IsElectrodesPresent(), HeartConfigRelatedCellFactory< SPACE_DIM >::mCellHeterogeneityAreas, HeartConfigRelatedCellFactory< SPACE_DIM >::mIonicModelRegions, HeartConfigRelatedCellFactory< SPACE_DIM >::mIonicModelsDefined, HeartConfigRelatedCellFactory< SPACE_DIM >::mParameterSettings, HeartConfigRelatedCellFactory< SPACE_DIM >::mScaleFactorGkr, HeartConfigRelatedCellFactory< SPACE_DIM >::mScaleFactorGks, HeartConfigRelatedCellFactory< SPACE_DIM >::mScaleFactorIto, HeartConfigRelatedCellFactory< SPACE_DIM >::mStimulatedAreas, HeartConfigRelatedCellFactory< SPACE_DIM >::mStimuliApplied, and HeartConfigRelatedCellFactory< SPACE_DIM >::PreconvertCellmlFiles().
HeartConfigRelatedCellFactory< SPACE_DIM >::~HeartConfigRelatedCellFactory | ( | ) | [inline] |
Destructor
Definition at line 106 of file HeartConfigRelatedCellFactory.cpp.
AbstractCardiacCellInterface * HeartConfigRelatedCellFactory< SPACE_DIM >::CreateCardiacCellForTissueNode | ( | Node< SPACE_DIM > * | pNode | ) | [inline] |
pNode | pointer to the node. |
Definition at line 337 of file HeartConfigRelatedCellFactory.cpp.
References HeartConfigRelatedCellFactory< SPACE_DIM >::CreateCellWithIntracellularStimulus(), Node< SPACE_DIM >::GetIndex(), Node< SPACE_DIM >::GetPoint(), HeartConfigRelatedCellFactory< SPACE_DIM >::mStimulatedAreas, and HeartConfigRelatedCellFactory< SPACE_DIM >::mStimuliApplied.
AbstractCardiacCellInterface * HeartConfigRelatedCellFactory< SPACE_DIM >::CreateCellWithIntracellularStimulus | ( | boost::shared_ptr< AbstractStimulusFunction > | intracellularStimulus, | |
unsigned | nodeIndex | |||
) | [inline] |
intracellularStimulus | is computed in CreateCardiacCellForTissueNode determined by the list of stimulation regions | |
nodeIndex | is the global index within the mesh |
Definition at line 111 of file HeartConfigRelatedCellFactory.cpp.
References EXCEPTION, HeartConfig::GetCheckpointSimulation(), AbstractCardiacCellInterface::GetLookupTableCollection(), AbstractCardiacCellFactory< SPACE_DIM >::GetMesh(), HeartConfig::Instance(), HeartConfigRelatedCellFactory< SPACE_DIM >::LoadDynamicModel(), HeartConfigRelatedCellFactory< SPACE_DIM >::mDefaultIonicModel, HeartConfigRelatedCellFactory< SPACE_DIM >::mIonicModelRegions, HeartConfigRelatedCellFactory< SPACE_DIM >::mIonicModelsDefined, AbstractCardiacCellFactory< SPACE_DIM >::mpSolver, NEVER_REACHED, and HeartConfigRelatedCellFactory< SPACE_DIM >::SetCellParameters().
Referenced by HeartConfigRelatedCellFactory< SPACE_DIM >::CreateCardiacCellForTissueNode().
void HeartConfigRelatedCellFactory< 3u >::FillInCellularTransmuralAreas | ( | ) | [inline, virtual] |
Method that fills in the vector of heterogeneity areas with the NodesLists that correspond to a given layer (implemented in subclasses)
Reimplemented from AbstractCardiacCellFactory< SPACE_DIM >.
Definition at line 363 of file HeartConfigRelatedCellFactory.cpp.
References HeartGeometryInformation< SPACE_DIM >::DetermineLayerForEachNode(), AbstractMesh< ELEMENT_DIM, SPACE_DIM >::GetDistributedVectorFactory(), HeartConfig::GetEndoLayerFraction(), HeartConfig::GetEndoLayerIndex(), HeartConfig::GetEpiLayerFraction(), HeartConfig::GetEpiLayerIndex(), AbstractCardiacCellFactory< SPACE_DIM >::GetMesh(), HeartConfig::GetMeshName(), HeartConfig::GetMidLayerIndex(), AbstractMesh< ELEMENT_DIM, SPACE_DIM >::GetNumNodes(), HeartConfig::Instance(), DistributedVectorFactory::IsGlobalIndexLocal(), HeartConfigRelatedCellFactory< SPACE_DIM >::mCellHeterogeneityAreas, NEVER_REACHED, and HeartGeometryInformation< SPACE_DIM >::rGetLayerForEachNode().
void HeartConfigRelatedCellFactory< SPACE_DIM >::FillInCellularTransmuralAreas | ( | ) | [inline, virtual] |
Helper method to calculate and fill in the heterogeneities areas (mCellHeterogeneityAreas)
Reimplemented from AbstractCardiacCellFactory< SPACE_DIM >.
Definition at line 357 of file HeartConfigRelatedCellFactory.cpp.
References NEVER_REACHED.
DynamicCellModelLoaderPtr HeartConfigRelatedCellFactory< SPACE_DIM >::LoadDynamicModel | ( | const cp::ionic_model_selection_type & | rModel, | |
bool | isCollective | |||
) | [inline, private] |
rModel | model to load | |
isCollective | whether we are being called collectively |
Definition at line 95 of file HeartConfigRelatedCellFactory.cpp.
Referenced by HeartConfigRelatedCellFactory< SPACE_DIM >::CreateCellWithIntracellularStimulus(), and HeartConfigRelatedCellFactory< SPACE_DIM >::PreconvertCellmlFiles().
void HeartConfigRelatedCellFactory< SPACE_DIM >::PreconvertCellmlFiles | ( | ) | [inline, private] |
Called by the constructor to convert any CellML files used as dynamically loaded cell models to shared libraries. This is necessary since the conversion process must be done collectively.
Definition at line 79 of file HeartConfigRelatedCellFactory.cpp.
References HeartConfigRelatedCellFactory< SPACE_DIM >::LoadDynamicModel(), HeartConfigRelatedCellFactory< SPACE_DIM >::mDefaultIonicModel, and HeartConfigRelatedCellFactory< SPACE_DIM >::mIonicModelsDefined.
Referenced by HeartConfigRelatedCellFactory< SPACE_DIM >::HeartConfigRelatedCellFactory().
void HeartConfigRelatedCellFactory< SPACE_DIM >::SetCellIntracellularStimulus | ( | AbstractCardiacCellInterface * | pCell, | |
unsigned | nodeIndex | |||
) | [inline] |
Set the intracellular stimulus for a cell based on the definitions in HeartConfig.
pCell | the cell to set stimulus of | |
nodeIndex | the index of the node corresponding to this cell in the mesh |
Definition at line 318 of file HeartConfigRelatedCellFactory.cpp.
References AbstractCardiacCellFactory< SPACE_DIM >::GetMesh(), HeartConfigRelatedCellFactory< SPACE_DIM >::mStimulatedAreas, HeartConfigRelatedCellFactory< SPACE_DIM >::mStimuliApplied, and AbstractCardiacCellInterface::SetIntracellularStimulusFunction().
Referenced by CardiacSimulation::CreateAndRun().
void HeartConfigRelatedCellFactory< SPACE_DIM >::SetCellParameters | ( | AbstractCardiacCellInterface * | pCell, | |
unsigned | nodeIndex | |||
) | [inline] |
Set parameters of a cell based on heterogeneity definitions in HeartConfig.
pCell | the cell to set parameters of | |
nodeIndex | the index of the node corresponding to this cell in the mesh |
#1166 applying Hill function for drug action
Definition at line 251 of file HeartConfigRelatedCellFactory.cpp.
References HeartConfig::GetDrugDose(), HeartConfig::GetIc50Values(), AbstractCardiacCellFactory< SPACE_DIM >::GetMesh(), AbstractCardiacCellInterface::GetParameter(), HeartConfig::Instance(), HeartConfigRelatedCellFactory< SPACE_DIM >::mCellHeterogeneityAreas, HeartConfigRelatedCellFactory< SPACE_DIM >::mParameterSettings, HeartConfigRelatedCellFactory< SPACE_DIM >::mScaleFactorGkr, HeartConfigRelatedCellFactory< SPACE_DIM >::mScaleFactorGks, HeartConfigRelatedCellFactory< SPACE_DIM >::mScaleFactorIto, and AbstractCardiacCellInterface::SetParameter().
Referenced by CardiacSimulation::CreateAndRun(), and HeartConfigRelatedCellFactory< SPACE_DIM >::CreateCellWithIntracellularStimulus().
std::vector<boost::shared_ptr<AbstractChasteRegion<SPACE_DIM> > > HeartConfigRelatedCellFactory< SPACE_DIM >::mCellHeterogeneityAreas [private] |
List of regions which represent areas in which to give parametric heterogeneity (scaling gating parameters) This vector will be filled in by the HeartConfig::GetCellHeterogeneity method if the user requested to specify the heterogeneity areas by cuboids, or, alternatively, by the FillInCellularTransmuralAreas method in the cell factory called by the problem class AFTER setting the mesh (which is needed for the calculations of the distance maps for the calculations of heterogeneities).
When creating a cardiac cell for each node (CreateCardiacCellForTissueNode) the code will check whether that node is contained in the heterogeneity area or not.
Definition at line 122 of file HeartConfigRelatedCellFactory.hpp.
Referenced by HeartConfigRelatedCellFactory< SPACE_DIM >::FillInCellularTransmuralAreas(), HeartConfigRelatedCellFactory< SPACE_DIM >::HeartConfigRelatedCellFactory(), and HeartConfigRelatedCellFactory< SPACE_DIM >::SetCellParameters().
cp::ionic_model_selection_type HeartConfigRelatedCellFactory< SPACE_DIM >::mDefaultIonicModel [private] |
Default cardiac cell model to be used in all tissue (except heterogeneous regions)
Definition at line 100 of file HeartConfigRelatedCellFactory.hpp.
Referenced by HeartConfigRelatedCellFactory< SPACE_DIM >::CreateCellWithIntracellularStimulus(), and HeartConfigRelatedCellFactory< SPACE_DIM >::PreconvertCellmlFiles().
std::vector<boost::shared_ptr<AbstractChasteRegion<SPACE_DIM> > > HeartConfigRelatedCellFactory< SPACE_DIM >::mIonicModelRegions [private] |
List of axis-aligned box regions which contain heterogeneous cardiac ionic model types
Definition at line 102 of file HeartConfigRelatedCellFactory.hpp.
Referenced by HeartConfigRelatedCellFactory< SPACE_DIM >::CreateCellWithIntracellularStimulus(), and HeartConfigRelatedCellFactory< SPACE_DIM >::HeartConfigRelatedCellFactory().
std::vector<cp::ionic_model_selection_type> HeartConfigRelatedCellFactory< SPACE_DIM >::mIonicModelsDefined [private] |
List of ionic model (size matches that of mIonicModelRegions)
Definition at line 104 of file HeartConfigRelatedCellFactory.hpp.
Referenced by HeartConfigRelatedCellFactory< SPACE_DIM >::CreateCellWithIntracellularStimulus(), HeartConfigRelatedCellFactory< SPACE_DIM >::HeartConfigRelatedCellFactory(), and HeartConfigRelatedCellFactory< SPACE_DIM >::PreconvertCellmlFiles().
std::vector<std::map<std::string, double> > HeartConfigRelatedCellFactory< SPACE_DIM >::mParameterSettings [private] |
Named parameters to be set in each region (size of list matches that of mCellHeterogeneityAreas)
Definition at line 131 of file HeartConfigRelatedCellFactory.hpp.
Referenced by HeartConfigRelatedCellFactory< SPACE_DIM >::HeartConfigRelatedCellFactory(), and HeartConfigRelatedCellFactory< SPACE_DIM >::SetCellParameters().
std::vector<double> HeartConfigRelatedCellFactory< SPACE_DIM >::mScaleFactorGkr [private] |
List of scale factors for Gkr scaling in each region (size of list matches that of mCellHeterogeneityAreas)
Definition at line 128 of file HeartConfigRelatedCellFactory.hpp.
Referenced by HeartConfigRelatedCellFactory< SPACE_DIM >::HeartConfigRelatedCellFactory(), and HeartConfigRelatedCellFactory< SPACE_DIM >::SetCellParameters().
std::vector<double> HeartConfigRelatedCellFactory< SPACE_DIM >::mScaleFactorGks [private] |
List of scale factors for Gks scaling in each region (size of list matches that of mCellHeterogeneityAreas)
Definition at line 124 of file HeartConfigRelatedCellFactory.hpp.
Referenced by HeartConfigRelatedCellFactory< SPACE_DIM >::HeartConfigRelatedCellFactory(), and HeartConfigRelatedCellFactory< SPACE_DIM >::SetCellParameters().
std::vector<double> HeartConfigRelatedCellFactory< SPACE_DIM >::mScaleFactorIto [private] |
List of scale factors for Ito scaling in each region (size of list matches that of mCellHeterogeneityAreas)
Definition at line 126 of file HeartConfigRelatedCellFactory.hpp.
Referenced by HeartConfigRelatedCellFactory< SPACE_DIM >::HeartConfigRelatedCellFactory(), and HeartConfigRelatedCellFactory< SPACE_DIM >::SetCellParameters().
std::vector<boost::shared_ptr<AbstractChasteRegion<SPACE_DIM> > > HeartConfigRelatedCellFactory< SPACE_DIM >::mStimulatedAreas [private] |
List of axis-aligned box or ellipsoid regions which represent areas to stimulate
Definition at line 107 of file HeartConfigRelatedCellFactory.hpp.
Referenced by HeartConfigRelatedCellFactory< SPACE_DIM >::CreateCardiacCellForTissueNode(), HeartConfigRelatedCellFactory< SPACE_DIM >::HeartConfigRelatedCellFactory(), and HeartConfigRelatedCellFactory< SPACE_DIM >::SetCellIntracellularStimulus().
std::vector<boost::shared_ptr<AbstractStimulusFunction> > HeartConfigRelatedCellFactory< SPACE_DIM >::mStimuliApplied [private] |
List of intracellular current stimuli to apply (size matches that of mStimulatedAreas)
Definition at line 109 of file HeartConfigRelatedCellFactory.hpp.
Referenced by HeartConfigRelatedCellFactory< SPACE_DIM >::CreateCardiacCellForTissueNode(), HeartConfigRelatedCellFactory< SPACE_DIM >::HeartConfigRelatedCellFactory(), and HeartConfigRelatedCellFactory< SPACE_DIM >::SetCellIntracellularStimulus().