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 #ifndef PRECONDITIONER_HPP
00026 #define PRECONDITIONER_HPP
00027 #include <Vector.hpp>
00028 #include <Problem.hpp>
00029
00030 #include <ErrorHandler.hpp>
00031
00032 #include <string>
00033
00044 class Preconditioner
00045 {
00046 public:
00047
00048 enum Type {
00049 none,
00050 diagonale,
00051 incompleteCholeskiFactorization,
00052 multigrid,
00053 spectralFEM
00054 };
00055
00056 protected:
00058 Preconditioner::Type __type;
00059
00060
00061 const Problem& __problem;
00062
00063 public:
00065 virtual void initializes() = 0;
00066
00068 virtual void computes(const Vector<real_t>& r ,
00069 Vector<real_t>& z) const = 0;
00070
00072 virtual void computesTransposed(const Vector<real_t>& r ,
00073 Vector<real_t>& z) const
00074 {
00075 this->computes(r,z);
00076 }
00077
00078 virtual std::string name() const = 0;
00079
00083 Preconditioner(const Problem& problem,
00084 const Preconditioner::Type& t)
00085 : __type(t),
00086 __problem(problem)
00087 {
00088 ;
00089 }
00090
00092 Preconditioner(const Preconditioner& P)
00093 : __type(P.__type),
00094 __problem(P.__problem)
00095 {
00096 ;
00097 }
00098
00099
00100 const Preconditioner::Type& Type() const
00101 {
00102 return __type;
00103 }
00104
00106 virtual ~Preconditioner()
00107 {
00108 ;
00109 }
00110 };
00111
00112 #endif // PRECONDITIONER_HPP
00113