00001 /* @HEADER@ */ 00002 /* *********************************************************************** 00003 // 00004 // TSFExtended: Trilinos Solver Framework Extended 00005 // Copyright (2004) Sandia Corporation 00006 // 00007 // Under terms of Contract DE-AC04-94AL85000, there is a non-exclusive 00008 // license for use of this work by or on behalf of the U.S. Government. 00009 // 00010 // This library is free software; you can redistribute it and/or modify 00011 // it under the terms of the GNU Lesser General Public License as 00012 // published by the Free Software Foundation; either version 2.1 of the 00013 // License, or (at your option) any later version. 00014 // 00015 // This library is distributed in the hope that it will be useful, but 00016 // WITHOUT ANY WARRANTY; without even the implied warranty of 00017 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00018 // Lesser General Public License for more details. 00019 // 00020 // You should have received a copy of the GNU Lesser General Public 00021 // License along with this library; if not, write to the Free Software 00022 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 00023 // USA 00024 // Questions? Contact Michael A. Heroux (maherou@sandia.gov) 00025 // 00026 // **********************************************************************/ 00027 /* @HEADER@ */ 00028 00029 #ifndef TSF_SIMPLE_DIAGONAL_OP_IMPL_HPP 00030 #define TSF_SIMPLE_DIAGONAL_OP_IMPL_HPP 00031 00032 00033 00034 #include "TSFSimpleDiagonalOpDecl.hpp" 00035 #include "SundanceOut.hpp" 00036 #include "SundanceTabs.hpp" 00037 00038 #ifndef HAVE_TEUCHOS_EXPLICIT_INSTANTIATION 00039 #include "TSFVectorImpl.hpp" 00040 #include "TSFSimplifiedLinearOpBaseImpl.hpp" 00041 #endif 00042 00043 00044 namespace TSFExtended 00045 { 00046 using namespace Teuchos; 00047 using namespace Sundance; 00048 00049 00050 00051 /* 00052 * --- scaled op 00053 */ 00054 00055 template <class Scalar> inline 00056 SimpleDiagonalOp<Scalar>::SimpleDiagonalOp( 00057 const Vector<Scalar>& diag) 00058 : SimplifiedLinearOpWithSpaces<Scalar>( 00059 diag.space(), diag.space() 00060 ), diag_(diag) 00061 {} 00062 00063 /* */ 00064 template <class Scalar> inline 00065 void SimpleDiagonalOp<Scalar>::applyOp(const Thyra::EOpTransp M_trans, 00066 const Vector<Scalar>& in, 00067 Vector<Scalar> out) const 00068 { 00069 Tabs tab(0); 00070 SUNDANCE_MSG2(this->verb(), tab << "SimpleDiagonalOp::applyOp()"); 00071 00072 Vector<Scalar> tmp = in.dotStar(diag_); 00073 out.acceptCopyOf(tmp); 00074 00075 SUNDANCE_MSG2(this->verb(), tab << "done SimpleDiagonalOp::applyOp()"); 00076 } 00077 00078 /* */ 00079 template <class Scalar> inline 00080 std::string SimpleDiagonalOp<Scalar>::description() const 00081 { 00082 return "DiagonalOp[diag=" + diag_.description() + "]"; 00083 } 00084 00085 00086 /* */ 00087 template <class Scalar> inline 00088 void SimpleDiagonalOp<Scalar>::print(std::ostream& os) const 00089 { 00090 Tabs tab(0); 00091 os << tab << "DiagonalOp[" << std::endl; 00092 Tabs tab1; 00093 os << tab1 << "diag = " << diag_ << std::endl; 00094 os << tab << "]" << std::endl; 00095 } 00096 00097 00098 00099 template <class Scalar> inline 00100 LinearOperator<Scalar> diagonalOperator( 00101 const Vector<Scalar>& diag) 00102 { 00103 RCP<LinearOpBase<Scalar> > A 00104 = rcp(new SimpleDiagonalOp<Scalar>(diag)); 00105 00106 return A; 00107 } 00108 00109 00110 00111 } 00112 00113 #endif