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 THYRA_SINGLE_RHS_LINEAR_OP_WITH_SOLVE_BASE_DECL_HPP
00030 #define THYRA_SINGLE_RHS_LINEAR_OP_WITH_SOLVE_BASE_DECL_HPP
00031
00032 #include "Thyra_SingleScalarLinearOpWithSolveBaseDecl.hpp"
00033 #include "Thyra_SingleRhsLinearOpBaseDecl.hpp"
00034
00035 namespace Thyra {
00036
00038 template <class Scalar>
00039 class SingleRhsLinearOpWithSolveBase
00040 : virtual public SingleScalarLinearOpWithSolveBase<Scalar>
00041 , virtual protected SingleRhsLinearOpBase<Scalar>
00042 {
00043 public:
00044
00047
00049 void solve(
00050 const ETransp M_trans
00051 ,const MultiVectorBase<Scalar> &B
00052 ,MultiVectorBase<Scalar> *X
00053 ,const int numBlocks
00054 ,const BlockSolveCriteria<Scalar> blockSolveCriteria[]
00055 ,SolveStatus<Scalar> blockSolveStatus[]
00056 ) const;
00057
00059
00060 protected:
00061
00064
00066 virtual SolveStatus<Scalar> solve(
00067 const ETransp M_trans
00068 ,const VectorBase<Scalar> &b
00069 ,VectorBase<Scalar> *x
00070 ,const SolveCriteria<Scalar> *solveCriteria
00071 ) const = 0;
00072
00074
00075 };
00076
00077 }
00078
00079 #endif // THYRA_SINGLE_RHS_LINEAR_OP_WITH_SOLVE_BASE_DECL_HPP