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 _MOCKEULERIVPODESOLVER_HPP_
00030 #define _MOCKEULERIVPODESOLVER_HPP_
00031
00032 #include <boost/serialization/access.hpp>
00033 #include <boost/serialization/base_object.hpp>
00034
00035 #include "EulerIvpOdeSolver.hpp"
00036
00037
00038 #include <boost/serialization/export.hpp>
00039
00046 class MockEulerIvpOdeSolver : public EulerIvpOdeSolver
00047 {
00048 private:
00050 friend class boost::serialization::access;
00057 template<class Archive>
00058 void serialize(Archive & archive, const unsigned int version)
00059 {
00060
00061 archive & boost::serialization::base_object<EulerIvpOdeSolver>(*this);
00062 archive & mCallCount;
00063 }
00064
00066 unsigned mCallCount;
00067
00068 protected:
00069
00081 virtual void InternalSolve(AbstractOdeSystem* pAbstractOdeSystem,
00082 std::vector<double>& rCurrentYValues,
00083 std::vector<double>& rWorkingMemory,
00084 double startTime,
00085 double endTime,
00086 double timeStep);
00087
00088 public:
00089
00093 MockEulerIvpOdeSolver();
00094
00100 unsigned GetCallCount();
00101
00105 virtual ~MockEulerIvpOdeSolver()
00106 {}
00107
00108 };
00109
00110 BOOST_CLASS_EXPORT(MockEulerIvpOdeSolver);
00111
00112 #endif //_MOCKEULERIVPODESOLVER_HPP_