Go to the documentation of this file.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 TSFIFPACKOPERATOR_HPP
00030 #define TSFIFPACKOPERATOR_HPP
00031
00032
00033 #include "TSFEpetraMatrix.hpp"
00034 #include "TSFOpWithBackwardsCompatibleApply.hpp"
00035 #include "Ifpack_IlukGraph.h"
00036 #include "Ifpack_CrsRiluk.h"
00037
00038
00039 namespace TSFExtended
00040 {
00041
00042
00043
00044 class IfpackOperator :
00045 public OpWithBackwardsCompatibleApply<double>
00046 {
00047 public:
00048
00049 IfpackOperator(const EpetraMatrix* A,
00050 int fillLevels,
00051 int overlapFill,
00052 double relaxationValue,
00053 double relativeThreshold,
00054 double absoluteThreshold);
00055
00056
00057 virtual bool opSupportedImpl(Thyra::EOpTransp M_trans) const;
00058
00059
00060
00061
00062
00063 virtual void generalApply(const Thyra::EOpTransp M_trans,
00064 const Thyra::VectorBase<double> &x,
00065 Thyra::VectorBase<double> *y,
00066 const double alpha=1.0,
00067 const double beta=0.0) const ;
00068
00069
00070
00071 virtual RCP< const Thyra::VectorSpaceBase<double> > domain() const {return domain_;}
00072
00073
00074 virtual RCP< const Thyra::VectorSpaceBase<double> > range() const {return range_;}
00075
00076
00077 private:
00078 RCP<Ifpack_IlukGraph> precondGraph_;
00079
00080 RCP<Ifpack_CrsRiluk> precond_;
00081
00082 RCP<const Thyra::VectorSpaceBase<double> > domain_;
00083
00084 RCP<const Thyra::VectorSpaceBase<double> > range_;
00085 };
00086 }
00087
00088 #endif