AbstractIvpOdeSolver.hpp
00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029 #ifndef _ABSTRACTIVPODESOLVER_HPP_
00030 #define _ABSTRACTIVPODESOLVER_HPP_
00031
00032 #include "ChasteSerialization.hpp"
00033 #include "ClassIsAbstract.hpp"
00034
00035 #include "OdeSolution.hpp"
00036 #include "AbstractOdeSystem.hpp"
00037
00042 class AbstractIvpOdeSolver
00043 {
00045 friend class boost::serialization::access;
00052 template<class Archive>
00053 void serialize(Archive & archive, const unsigned int version)
00054 {
00055 archive & mStoppingEventOccurred;
00056 archive & mStoppingTime;
00057 }
00058
00059 protected :
00060
00065 bool mStoppingEventOccurred;
00066
00068 double mStoppingTime;
00069
00070 public :
00071
00091 virtual OdeSolution Solve(AbstractOdeSystem* pAbstractOdeSystem,
00092 std::vector<double>& rYValues,
00093 double startTime,
00094 double endTime,
00095 double timeStep,
00096 double timeSampling)=0;
00097
00113 virtual void Solve(AbstractOdeSystem* pAbstractOdeSystem,
00114 std::vector<double>& rYValues,
00115 double startTime,
00116 double endTime,
00117 double timeStep)=0;
00118
00129 virtual void SolveAndUpdateStateVariable(AbstractOdeSystem* pAbstractOdeSystem,
00130 double startTime,
00131 double endTime,
00132 double timeStep);
00133
00138 bool StoppingEventOccurred();
00139
00145 double GetStoppingTime();
00146
00150 AbstractIvpOdeSolver();
00151
00155 virtual ~AbstractIvpOdeSolver();
00156
00157 };
00158
00159 CLASS_IS_ABSTRACT(AbstractIvpOdeSolver)
00160
00161 #endif //_ABSTRACTIVPODESOLVER_HPP_