Thyra_InverseLinearOperator.hpp

00001 // ***********************************************************************
00002 // 
00003 //    Thyra: Interfaces and Support for Abstract Numerical Algorithms
00004 //                 Copyright (2004) Sandia Corporation
00005 // 
00006 // Under terms of Contract DE-AC04-94AL85000, there is a non-exclusive
00007 // license for use of this work by or on behalf of the U.S. Government.
00008 // 
00009 // This library is free software; you can redistribute it and/or modify
00010 // it under the terms of the GNU Lesser General Public License as
00011 // published by the Free Software Foundation; either version 2.1 of the
00012 // License, or (at your option) any later version.
00013 //  
00014 // This library is distributed in the hope that it will be useful, but
00015 // WITHOUT ANY WARRANTY; without even the implied warranty of
00016 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00017 // Lesser General Public License for more details.
00018 //  
00019 // You should have received a copy of the GNU Lesser General Public
00020 // License along with this library; if not, write to the Free Software
00021 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
00022 // USA
00023 // Questions? Contact Michael A. Heroux (maherou@sandia.gov) 
00024 // 
00025 // ***********************************************************************
00026 // @HEADER
00027 
00028 #ifndef THYRA_INVERSE_LINEAR_OPERATOR_HPP
00029 #define THYRA_INVERSE_LINEAR_OPERATOR_HPP
00030 
00031 #include "Thyra_LinearOperatorImpl.hpp"
00032 #include "Thyra_DefaultInverseLinearOp.hpp"
00033 #include "Thyra_LinearOpWithSolveFactoryHelpers.hpp"
00034 
00035 namespace Thyra {
00036 
00058 template<class Scalar>
00059 LinearOperator<Scalar>
00060 inverse(
00061   LinearOpWithSolveFactoryBase<Scalar>    const&  lowsf
00062   ,ConstLinearOperator<Scalar>            const&  fwdOp
00063   ,EThrowOnSolveFailure                           throwOnSolveFailure  = THROW_ON_SOLVE_FAILURE
00064   ,LinearOperator<Scalar>                 const&  prevInverseOp        = Teuchos::null
00065   )
00066 {
00067   return inverse<Scalar>(
00068     linearOpWithSolve(lowsf,fwdOp.constPtr())
00069     ,NULL,throwOnSolveFailure
00070     ,NULL,throwOnSolveFailure
00071     );
00072 }
00073 
00074 } // end namespace Thyra
00075 
00076 #endif  // THYRA_INVERSE_LINEAR_OPERATOR_HPP

Generated on Tue Oct 20 12:47:11 2009 for Thyra Operator Solve Support by doxygen 1.4.7