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 <vector>
00033
00034 #include "ChasteSerialization.hpp"
00035 #include "ClassIsAbstract.hpp"
00036
00037 #include "OdeSolution.hpp"
00038 #include "AbstractOdeSystem.hpp"
00039
00044 class AbstractIvpOdeSolver
00045 {
00047 friend class boost::serialization::access;
00054 template<class Archive>
00055 void serialize(Archive & archive, const unsigned int version)
00056 {
00057 archive & mStoppingEventOccurred;
00058 archive & mStoppingTime;
00059 }
00060
00061 protected :
00062
00067 bool mStoppingEventOccurred;
00068
00070 double mStoppingTime;
00071
00072 public :
00073
00093 virtual OdeSolution Solve(AbstractOdeSystem* pAbstractOdeSystem,
00094 std::vector<double>& rYValues,
00095 double startTime,
00096 double endTime,
00097 double timeStep,
00098 double timeSampling)=0;
00099
00115 virtual void Solve(AbstractOdeSystem* pAbstractOdeSystem,
00116 std::vector<double>& rYValues,
00117 double startTime,
00118 double endTime,
00119 double timeStep)=0;
00120
00131 virtual void SolveAndUpdateStateVariable(AbstractOdeSystem* pAbstractOdeSystem,
00132 double startTime,
00133 double endTime,
00134 double timeStep);
00135
00140 bool StoppingEventOccurred();
00141
00147 double GetStoppingTime();
00148
00152 AbstractIvpOdeSolver();
00153
00157 virtual ~AbstractIvpOdeSolver();
00158
00159 };
00160
00161 CLASS_IS_ABSTRACT(AbstractIvpOdeSolver)
00162
00163 #endif //_ABSTRACTIVPODESOLVER_HPP_