00001 // Copyright (C) 2002-2004 Vivien Mallet 00002 // 00003 // This file is part of Multivac library. 00004 // Multivac library provides front-tracking algorithms. 00005 // 00006 // Multivac is free software; you can redistribute it and/or modify 00007 // it under the terms of the GNU General Public License as published by 00008 // the Free Software Foundation; either version 2 of the License, or 00009 // (at your option) any later version. 00010 // 00011 // Multivac is distributed in the hope that it will be useful, 00012 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00013 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00014 // GNU General Public License (file "license") for more details. 00015 // 00016 // For more information, please see the Multivac home page: 00017 // http://spacetown.free.fr/fronts/ 00018 00019 00020 #ifndef FILE_LEVELSETS_BASECLASS_HXX 00021 00022 00023 #include "../errors.cxx" 00024 #include <stdio.h> 00025 00026 00027 namespace Multivac 00028 { 00029 00030 00032 // CLEVELSET // 00034 00036 00041 template <class T> 00042 class CLevelSet 00043 { 00044 00045 00046 /************** 00047 * ATTRIBUTES * 00048 **************/ 00049 00050 protected: 00051 00053 Matrix<T> Values; 00054 00055 00056 /***************************** 00057 * CONSTRUCTORS & DESTRUCTOR * 00058 *****************************/ 00059 00060 public: 00061 00062 CLevelSet() throw(); 00063 00064 virtual ~CLevelSet() throw(); 00065 00066 00067 /*********** 00068 * METHODS * 00069 ***********/ 00070 00071 public: 00072 00073 virtual void Init(CMesh<T>& Mesh) = 0; 00074 virtual void Reallocate(int i, int j); 00075 00076 Matrix<T>& GetValues(); 00077 virtual T& operator() (int i, int j); 00078 00079 virtual void Save(string PhiFile) const = 0; 00080 00081 }; // CLevelSet. 00082 00083 00084 } // namespace Multivac. 00085 00086 00087 #define FILE_LEVELSETS_BASECLASS_HXX 00088 #endif