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 TSFEIGENSOLVER_HPP
00030 #define TSFEIGENSOLVER_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 Eigensolver : public Sundance::Handle<EigensolverBase<Scalar> >
00047 {
00048 public:
00049
00050 Eigensolver() : Handle<EigensolverBase<Scalar> >() {;}
00051
00052 Eigensolver( Sundance::Handleable<EigensolverBase<Scalar> >* rawPtr)
00053 : Handle<EigensolverBase<Scalar> >(rawPtr) {;}
00054
00055 Eigensolver(const RCP<EigensolverBase<Scalar> >& smartPtr)
00056 : Handle<EigensolverBase<Scalar> >(smartPtr) {;}
00057
00058
00059
00060 void solve(
00061 const LinearOperator<Scalar>& K,
00062 const LinearOperator<Scalar>& M,
00063 Array<Vector<Scalar> >& ev,
00064 Array<std::complex<Scalar> >& ew) const
00065 {
00066 this->ptr()->solve(K, M, ev, ew);
00067 }
00068
00069
00070 void solve(
00071 const LinearOperator<Scalar>& K,
00072 Array<Vector<Scalar> >& ev,
00073 Array<std::complex<Scalar> >& ew) const
00074 {
00075 this->ptr()->solve(K, ev, ew);
00076 }
00077
00078
00079 const ParameterList& params() const
00080 {
00081 TEST_FOR_EXCEPTION(this->ptr().get()==0, std::runtime_error,
00082 "null pointer in Eigensolver::parameters()");
00083 return this->ptr()->params();
00084 }
00085
00086
00087 ParameterList& params()
00088 {
00089 TEST_FOR_EXCEPTION(this->ptr().get()==0, std::runtime_error,
00090 "null pointer in Eigensolver::parameters()");
00091 return this->ptr()->params();
00092 }
00093
00094
00095 static FancyOStream& os()
00096 {
00097 return ObjectWithClassVerbosity<EigensolverBase<Scalar> >::os();
00098 }
00099 };
00100
00101
00102
00103 }
00104
00105
00106 #endif