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 TSFANASAZIEIGENSOLVER_DECL_HPP
00030 #define TSFANASAZIEIGENSOLVER_DECL_HPP
00031
00032 #include "SundanceDefs.hpp"
00033 #include "TSFVectorDecl.hpp"
00034 #include "TSFSolverState.hpp"
00035 #include "Teuchos_ParameterList.hpp"
00036 #include "TSFEigensolverBase.hpp"
00037
00038 namespace TSFExtended
00039 {
00040 using Teuchos::ParameterList;
00041
00042
00043
00044
00045 template <class Scalar>
00046 class AnasaziEigensolver
00047 : public EigensolverBase<Scalar>,
00048 public Sundance::Handleable<EigensolverBase<Scalar> >
00049 {
00050 public:
00051
00052 AnasaziEigensolver(const ParameterList& params)
00053 : EigensolverBase<Scalar>(params) {;}
00054
00055
00056
00057
00058 virtual void solve(
00059 const LinearOperator<Scalar>& K,
00060 const LinearOperator<Scalar>& M,
00061 Array<Vector<Scalar> >& ev,
00062 Array<std::complex<Scalar> >& ew) const ;
00063
00064
00065
00066
00067 virtual RCP<EigensolverBase<Scalar> > getRcp()
00068 {return rcp(this);}
00069
00070
00071 private:
00072
00073 static Time& solveTimer()
00074 {
00075 static RCP<Time> rtn
00076 = TimeMonitor::getNewTimer("AnasaziEigensolver solve()");
00077 return *rtn;
00078 }
00079
00080 static Time& precondBuildTimer()
00081 {
00082 static RCP<Time> rtn
00083 = TimeMonitor::getNewTimer("AnasaziEigensolver building preconditioner");
00084 return *rtn;
00085 }
00086
00087 };
00088
00089
00090
00091
00092 }
00093
00094
00095 #endif