00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020 #ifndef FILE_INITIALCURVES_BASECLASS_HXX
00021
00022
00023 #include "../errors.cxx"
00024 #include <stdio.h>
00025
00026
00027 namespace Multivac
00028 {
00029
00030
00032
00034
00036
00041 template <class T>
00042 class CInitialCurve
00043 {
00044
00045
00046
00047
00048
00049 protected:
00050
00052 Curve<T> Curve;
00053
00055 bool reversed;
00056
00057
00058
00059
00060
00061
00062 public:
00063
00064 CInitialCurve() throw();
00065
00066 virtual ~CInitialCurve() throw();
00067
00068
00069
00070
00071
00072
00073 public:
00074
00075 virtual void SetDistances(CMesh<T>& Mesh, CLevelSet<T>& Phi) = 0;
00076 virtual T GetDistance(T x, T y) = 0;
00077
00078 virtual void GetProjectionOnMesh(T& x, T& y, CMesh<T>& Mesh) = 0;
00079
00080 virtual void Save(string CurveFile) const = 0;
00081
00082 };
00083
00084
00085 }
00086
00087
00088 #define FILE_INITIALCURVES_BASECLASS_HXX
00089 #endif