00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020 #ifndef FILE_SIMULATOR_HXX
00021
00022
00023 #include "errors.cxx"
00024 #include <stdio.h>
00025
00026
00027 namespace Multivac
00028 {
00029
00030
00031 template <class T, class MeshType, class SpeedType, class InitialCurveType,
00032 class LevelSetType, class InitializerType, class UpdaterType,
00033 class SaverType>
00034 class CSimulator
00035 {
00036
00037
00038
00039
00040
00041 protected:
00042
00043
00044 MeshType Mesh;
00045 SpeedType F;
00046 InitialCurveType InitialCurve;
00047 LevelSetType Phi;
00048 InitializerType Initializer;
00049 UpdaterType Updater;
00050 SaverType Saver;
00051
00052 int NbIterations;
00053 T FinalTime;
00054 T Delta_t;
00055
00056
00057
00058
00059
00060
00061 public:
00062
00063 CSimulator(MeshType& Mesh_, SpeedType& F_,
00064 InitialCurveType& InitialCurve_, LevelSetType& Phi_,
00065 InitializerType& Initializer_, UpdaterType& Updater_,
00066 SaverType& Saver_,
00067 int NbIterations_, T FinalTime_) throw();
00068
00069 ~CSimulator() throw();
00070
00071
00072
00073
00074
00075
00076 public:
00077
00078 void Init();
00079
00080 void Run();
00081
00082 InitializerType& GetInitializer();
00083 SpeedType& GetSpeedFunction();
00084
00085 };
00086
00087
00088 }
00089
00090
00091 #define FILE_SIMULATOR_HXX
00092 #endif