Chaste  Release::2017.1
ElectrodesStimulusFactory< DIM > Class Template Reference

#include <ElectrodesStimulusFactory.hpp>

+ Inheritance diagram for ElectrodesStimulusFactory< DIM >:
+ Collaboration diagram for ElectrodesStimulusFactory< DIM >:

Public Member Functions

 ElectrodesStimulusFactory (std::vector< std::pair< AbstractChasteRegion< DIM > *, AbstractChasteRegion< DIM > * > > &rElectrodePairs, std::vector< double > &rStimulusMagnitudes, std::vector< double > &rDurations, std::vector< double > &rPeriods, std::vector< double > &rStarts, std::vector< double > &rEnds)
 
boost::shared_ptr< AbstractStimulusFunctionCreateStimulusForNode (Node< DIM > *pNode)
 
 ~ElectrodesStimulusFactory ()
 
void SetCompatibleExtracellularStimulus ()
 
void GroundSecondElectrode (bool grounded)
 
- Public Member Functions inherited from AbstractStimulusFactory< DIM >
virtual boost::shared_ptr< AbstractStimulusFunctionCreateStimulusForNode (Node< ELEMENT_DIM > *pNode)
 
virtual unsigned GetNumberOfCells ()
 
 AbstractStimulusFactory ()
 
virtual ~AbstractStimulusFactory ()
 
void SetMesh (AbstractTetrahedralMesh< ELEMENT_DIM, ELEMENT_DIM > *pMesh)
 
AbstractTetrahedralMesh< ELEMENT_DIM, ELEMENT_DIM > * GetMesh ()
 
std::vector< AbstractChasteRegion< ELEMENT_DIM > * > GetRegionsToBeGrounded ()
 

Protected Types

typedef LinearBasisFunction< DIM > BasisFunction
 

Protected Member Functions

void CheckForElectrodesIntersection ()
 
double ComputeElectrodeTotalFlux (AbstractChasteRegion< DIM > *pRegion, double stimulusMagnitude)
 

Protected Attributes

std::vector< std::pair< AbstractChasteRegion< DIM > *, AbstractChasteRegion< DIM > * > > & mrElectrodePairs
 
std::vector< double > & mrMagnitudes
 
std::vector< double > & mrDurations
 
std::vector< double > & mrPeriods
 
std::vector< double > & mrStarts
 
std::vector< double > & mrEnds
 
std::vector< doublemMagnitudesElectrode1
 
std::vector< doublemMagnitudesElectrode2
 
bool mGroundSecondElectrode
 
- Protected Attributes inherited from AbstractStimulusFactory< DIM >
AbstractTetrahedralMesh< ELEMENT_DIM, ELEMENT_DIM > * mpMesh
 
std::vector< AbstractChasteRegion< ELEMENT_DIM > * > mGroundedRegions
 

Friends

class TestStimulusFactory
 

Detailed Description

template<unsigned DIM>
class ElectrodesStimulusFactory< DIM >

This class implements the specification of tow electrodes with a RegularStimulus applied to them. It makes sure the compatibility conditions is verified by scaling the magnitude of the second electrode according to the flux flowing thorugh each of them.

User needs to pass in a vector of pairs of electrodes and, for each pair, the stimulation parameters. This class will then implement the CreateStimulusForNode accordingly by creating a RegularStimulus object for each node. Each node belonging to any "first electrode" will have an extracellular volume stimulus equals to the value that is passed in, while each node belonging to any "second elecrode" will have an extracellular volume stimulus corrected by the flux (proportional to electrode volume) in such a way that compatibility conditions of the extended bidomain equations are followed.

It is possible to ground all second electrodes by calling GroundSecondElectrode. In this case, the member variable mGroundSecondElectrode will have size > 0 and other classes can behave accordingly (e.g., problem class will set Dirichlet boundary conditions accordingly).

Definition at line 67 of file ElectrodesStimulusFactory.hpp.

Member Typedef Documentation

template<unsigned DIM>
typedef LinearBasisFunction<DIM> ElectrodesStimulusFactory< DIM >::BasisFunction
protected

typedef for basis function

Definition at line 121 of file ElectrodesStimulusFactory.hpp.

Constructor & Destructor Documentation

template<unsigned DIM>
ElectrodesStimulusFactory< DIM >::ElectrodesStimulusFactory ( std::vector< std::pair< AbstractChasteRegion< DIM > *, AbstractChasteRegion< DIM > * > > &  rElectrodePairs,
std::vector< double > &  rStimulusMagnitudes,
std::vector< double > &  rDurations,
std::vector< double > &  rPeriods,
std::vector< double > &  rStarts,
std::vector< double > &  rEnds 
)

Constructor. Electrodes and stimulation parameters need to be passed in.

Parameters
rElectrodePairsthe pairs of electrodes
rStimulusMagnitudesthe magnitudes of the stimuli (microA / cm^3). First electrode will have magnitude value and second electrode will have -magnitude (before being corrected to ensure equal flux).
rDurationsthe duration of each stimulus (ms)
rPeriodsthe period of each stimulus (ms)
rStartsthe start time of each stimulus (ms).
rEndsthe end of each stimulation (ms)

Definition at line 44 of file ElectrodesStimulusFactory.cpp.

References EXCEPTION, ElectrodesStimulusFactory< DIM >::mMagnitudesElectrode1, ElectrodesStimulusFactory< DIM >::mMagnitudesElectrode2, and ElectrodesStimulusFactory< DIM >::mrMagnitudes.

template<unsigned DIM>
ElectrodesStimulusFactory< DIM >::~ElectrodesStimulusFactory ( )

Destructor

Definition at line 72 of file ElectrodesStimulusFactory.cpp.

Member Function Documentation

template<unsigned DIM>
void ElectrodesStimulusFactory< DIM >::CheckForElectrodesIntersection ( )
protected
template<unsigned DIM>
double ElectrodesStimulusFactory< DIM >::ComputeElectrodeTotalFlux ( AbstractChasteRegion< DIM > *  pRegion,
double  stimulusMagnitude 
)
protected

Helper method to compute electrode flux. This method is the main functionality of this class.

It essentially computes the contribution of each electrode to the RHS vector of the linear system. The loops over elements and gauss points mimicks the ones in AssembleOnElement. Interpolation is done for the value of the magnitude of the electrode.

NOTE that this method assumes the use of a 2nd order Gauss quadrature rule (the default value of Chaste FE assemblers).

Parameters
pRegionthe electrode
stimulusMagnitudethe stimulus magnitude
Returns
electrode flux

Definition at line 185 of file ElectrodesStimulusFactory.cpp.

References LinearBasisFunction< ELEMENT_DIM >::ComputeBasisFunctions(), AbstractChasteRegion< SPACE_DIM >::DoesContain(), AbstractTetrahedralMesh< ELEMENT_DIM, SPACE_DIM >::GetElement(), AbstractElement< ELEMENT_DIM, SPACE_DIM >::GetIndex(), AbstractTetrahedralMesh< ELEMENT_DIM, SPACE_DIM >::GetInverseJacobianForElement(), AbstractMesh< ELEMENT_DIM, SPACE_DIM >::GetNode(), AbstractMesh< ELEMENT_DIM, SPACE_DIM >::GetNodeIteratorBegin(), AbstractMesh< ELEMENT_DIM, SPACE_DIM >::GetNodeIteratorEnd(), AbstractElement< ELEMENT_DIM, SPACE_DIM >::GetNumNodes(), AbstractMesh< ELEMENT_DIM, SPACE_DIM >::GetNumNodes(), GaussianQuadratureRule< ELEMENT_DIM >::GetNumQuadPoints(), GaussianQuadratureRule< ELEMENT_DIM >::GetWeight(), AbstractStimulusFactory< DIM >::mpMesh, and GaussianQuadratureRule< ELEMENT_DIM >::rGetQuadPoint().

Referenced by ElectrodesStimulusFactory< DIM >::SetCompatibleExtracellularStimulus().

template<unsigned DIM>
boost::shared_ptr< AbstractStimulusFunction > ElectrodesStimulusFactory< DIM >::CreateStimulusForNode ( Node< DIM > *  pNode)
template<unsigned DIM>
void ElectrodesStimulusFactory< DIM >::GroundSecondElectrode ( bool  grounded)

Allow the user to ground the second electrode

Parameters
grounded: true if second electrode is grounded

Definition at line 116 of file ElectrodesStimulusFactory.cpp.

References ElectrodesStimulusFactory< DIM >::mGroundSecondElectrode.

template<unsigned DIM>
void ElectrodesStimulusFactory< DIM >::SetCompatibleExtracellularStimulus ( )
virtual

Member Data Documentation

template<unsigned DIM>
bool ElectrodesStimulusFactory< DIM >::mGroundSecondElectrode
protected
template<unsigned DIM>
std::vector<double>& ElectrodesStimulusFactory< DIM >::mrDurations
protected

Vector of stimuli durations (ms). Must be the same size as mrElectrodePairs.

Definition at line 85 of file ElectrodesStimulusFactory.hpp.

Referenced by ZeroNetChargeElectrodes< DIM >::CreateStimulusForNode(), and ElectrodesStimulusFactory< DIM >::CreateStimulusForNode().

template<unsigned DIM>
std::vector<double>& ElectrodesStimulusFactory< DIM >::mrEnds
protected

Vector of stimuli end times (ms). Must be the same size as mrElectrodePairs.

Definition at line 97 of file ElectrodesStimulusFactory.hpp.

Referenced by ZeroNetChargeElectrodes< DIM >::CreateStimulusForNode(), and ElectrodesStimulusFactory< DIM >::CreateStimulusForNode().

template<unsigned DIM>
std::vector<double>& ElectrodesStimulusFactory< DIM >::mrMagnitudes
protected

Vector of stimuli magnitudes (microA / cm^3). Must be the same size as mrElectrodePairs.

Definition at line 81 of file ElectrodesStimulusFactory.hpp.

Referenced by ElectrodesStimulusFactory< DIM >::ElectrodesStimulusFactory().

template<unsigned DIM>
std::vector<double>& ElectrodesStimulusFactory< DIM >::mrPeriods
protected

Vector of stimuli periods (ms). Must be the same size as mrElectrodePairs.

Definition at line 89 of file ElectrodesStimulusFactory.hpp.

Referenced by ZeroNetChargeElectrodes< DIM >::CreateStimulusForNode(), and ElectrodesStimulusFactory< DIM >::CreateStimulusForNode().

template<unsigned DIM>
std::vector<double>& ElectrodesStimulusFactory< DIM >::mrStarts
protected

Vector of stimuli start times (ms). Must be the same size as mrElectrodePairs.

Definition at line 93 of file ElectrodesStimulusFactory.hpp.

Referenced by ZeroNetChargeElectrodes< DIM >::CreateStimulusForNode(), and ElectrodesStimulusFactory< DIM >::CreateStimulusForNode().


The documentation for this class was generated from the following files: