LinearOpBase subclass that creates an implicit LinearOpBase object using the inverse action of a LinearOpWithSolveBase object.
More...
#include <Thyra_DefaultInverseLinearOpDecl.hpp>
Constructors/initializers/accessors | |
| DefaultInverseLinearOp () | |
Constructs to uninitialized (see postconditions for uninitialize()). | |
| DefaultInverseLinearOp (const Teuchos::RCP< LinearOpWithSolveBase< Scalar > > &lows, const SolveCriteria< Scalar > *fwdSolveCriteria=NULL, const EThrowOnSolveFailure throwOnFwdSolveFailure=THROW_ON_SOLVE_FAILURE, const SolveCriteria< Scalar > *adjSolveCriteria=NULL, const EThrowOnSolveFailure throwOnAdjSolveFailure=THROW_ON_SOLVE_FAILURE) | |
| DefaultInverseLinearOp (const Teuchos::RCP< const LinearOpWithSolveBase< Scalar > > &lows, const SolveCriteria< Scalar > *fwdSolveCriteria=NULL, const EThrowOnSolveFailure throwOnFwdSolveFailure=THROW_ON_SOLVE_FAILURE, const SolveCriteria< Scalar > *adjSolveCriteria=NULL, const EThrowOnSolveFailure throwOnAdjSolveFailure=THROW_ON_SOLVE_FAILURE) | |
| void | initialize (const Teuchos::RCP< LinearOpWithSolveBase< Scalar > > &lows, const SolveCriteria< Scalar > *fwdSolveCriteria=NULL, const EThrowOnSolveFailure throwOnFwdSolveFailure=THROW_ON_SOLVE_FAILURE, const SolveCriteria< Scalar > *adjSolveCriteria=NULL, const EThrowOnSolveFailure throwOnAdjSolveFailure=THROW_ON_SOLVE_FAILURE) |
Initialize given a non-const LinearOpWithSolveBase object and an optional . | |
| void | initialize (const Teuchos::RCP< const LinearOpWithSolveBase< Scalar > > &lows, const SolveCriteria< Scalar > *fwdSolveCriteria=NULL, const EThrowOnSolveFailure throwOnFwdSolveFailure=THROW_ON_SOLVE_FAILURE, const SolveCriteria< Scalar > *adjSolveCriteria=NULL, const EThrowOnSolveFailure throwOnAdjSolveFailure=THROW_ON_SOLVE_FAILURE) |
Initialize given a non-const LinearOpWithSolveBase object and an optional . | |
| void | uninitialize () |
| Set to uninitialized. | |
Overridden from InverseLinearOpBase | |
| bool | isLowsConst () const |
| | |
| Teuchos::RCP< LinearOpWithSolveBase< Scalar > > | getNonconstLows () |
| | |
| Teuchos::RCP< const LinearOpWithSolveBase< Scalar > > | getLows () const |
| | |
Overridden from LinearOpBase | |
| Teuchos::RCP< const VectorSpaceBase< Scalar > > | range () const |
Returns this->getLows()->domain() if <t>this->getLows().get()!=NULL and returns Teuchos::null otherwise. | |
| Teuchos::RCP< const VectorSpaceBase< Scalar > > | domain () const |
Returns this->getLows()->range() if <t>this->getLows().get()!=NULL and returns Teuchos::null otherwise. | |
| Teuchos::RCP< const LinearOpBase< Scalar > > | clone () const |
| | |
Overridden from Teuchos::Describable | |
| std::string | description () const |
| | |
| void | describe (Teuchos::FancyOStream &out, const Teuchos::EVerbosityLevel verbLevel) const |
| | |
Overridden from SingleScalarLinearOpBase | |
| bool | opSupported (EOpTransp M_trans) const |
Returns true only if all constituent operators support M_trans. | |
| void | apply (const EOpTransp M_trans, const MultiVectorBase< Scalar > &X, MultiVectorBase< Scalar > *Y, const Scalar alpha, const Scalar beta) const |
| | |
Related Functions | |
| (Note that these are not member functions.) | |
| Teuchos::RCP< LinearOpBase< Scalar > > | nonconstInverse (const Teuchos::RCP< LinearOpWithSolveBase< Scalar > > &A, const SolveCriteria< Scalar > *fwdSolveCriteria=NULL, const EThrowOnSolveFailure throwOnFwdSolveFailure=THROW_ON_SOLVE_FAILURE, const SolveCriteria< Scalar > *adjSolveCriteria=NULL, const EThrowOnSolveFailure throwOnAdjSolveFailure=THROW_ON_SOLVE_FAILURE) |
| Form a non-const implicit inverse operator <tt>M = inv(A). | |
| Teuchos::RCP< LinearOpBase< Scalar > > | inverse (const Teuchos::RCP< const LinearOpWithSolveBase< Scalar > > &A, const SolveCriteria< Scalar > *fwdSolveCriteria=NULL, const EThrowOnSolveFailure throwOnFwdSolveFailure=THROW_ON_SOLVE_FAILURE, const SolveCriteria< Scalar > *adjSolveCriteria=NULL, const EThrowOnSolveFailure throwOnAdjSolveFailure=THROW_ON_SOLVE_FAILURE) |
| Form a const implicit inverse operator <tt>M = inv(A). | |
LinearOpBase subclass that creates an implicit LinearOpBase object using the inverse action of a LinearOpWithSolveBase object.
This class represents an implicitly inverse linear operator:
M = inv(A)
where A is any LinearOpWithSolveBase object. Specifically, the solve(...) function A is used to implement this->apply() and the solveTranspose(...) function A is used to implement this->applyTranspose().
SolveCriteria objects can be associated with A to define the solve criterion for calling the A.solve(...,fwdSolveCriteria) and A.solveTranspose(...,adjSolveCriteria).
Definition at line 71 of file Thyra_DefaultInverseLinearOpDecl.hpp.
| Thyra::DefaultInverseLinearOp< Scalar >::DefaultInverseLinearOp | ( | ) |
Constructs to uninitialized (see postconditions for uninitialize()).
Definition at line 46 of file Thyra_DefaultInverseLinearOp.hpp.
| Thyra::DefaultInverseLinearOp< Scalar >::DefaultInverseLinearOp | ( | const Teuchos::RCP< LinearOpWithSolveBase< Scalar > > & | lows, | |
| const SolveCriteria< Scalar > * | fwdSolveCriteria = NULL, |
|||
| const EThrowOnSolveFailure | throwOnFwdSolveFailure = THROW_ON_SOLVE_FAILURE, |
|||
| const SolveCriteria< Scalar > * | adjSolveCriteria = NULL, |
|||
| const EThrowOnSolveFailure | throwOnAdjSolveFailure = THROW_ON_SOLVE_FAILURE | |||
| ) |
Calls initialize().
Definition at line 51 of file Thyra_DefaultInverseLinearOp.hpp.
| Thyra::DefaultInverseLinearOp< Scalar >::DefaultInverseLinearOp | ( | const Teuchos::RCP< const LinearOpWithSolveBase< Scalar > > & | lows, | |
| const SolveCriteria< Scalar > * | fwdSolveCriteria = NULL, |
|||
| const EThrowOnSolveFailure | throwOnFwdSolveFailure = THROW_ON_SOLVE_FAILURE, |
|||
| const SolveCriteria< Scalar > * | adjSolveCriteria = NULL, |
|||
| const EThrowOnSolveFailure | throwOnAdjSolveFailure = THROW_ON_SOLVE_FAILURE | |||
| ) |
Calls initialize().
Rather than calling this constructor directly, consider using the non-member helper functions described here.
Definition at line 67 of file Thyra_DefaultInverseLinearOp.hpp.
| void Thyra::DefaultInverseLinearOp< Scalar >::initialize | ( | const Teuchos::RCP< LinearOpWithSolveBase< Scalar > > & | lows, | |
| const SolveCriteria< Scalar > * | fwdSolveCriteria = NULL, |
|||
| const EThrowOnSolveFailure | throwOnFwdSolveFailure = THROW_ON_SOLVE_FAILURE, |
|||
| const SolveCriteria< Scalar > * | adjSolveCriteria = NULL, |
|||
| const EThrowOnSolveFailure | throwOnAdjSolveFailure = THROW_ON_SOLVE_FAILURE | |||
| ) |
Initialize given a non-const LinearOpWithSolveBase object and an optional .
| lows | [in] The LinearOpWithSolveBase object that will solve(...) and/or solveTranspose(...) will be called on. Note that *this may give up non-const views of *lows so that *lows may be changed through clients of this object. | |
| fwdSolveCriteria | [in] The criteria used to call lows->solve(...). If fwdSolveCriteria==NULL then the default solve criteria built into *lows | |
| adjSolveCriteria | |
lows.get() != NULL
Postconditions:
Definition at line 83 of file Thyra_DefaultInverseLinearOp.hpp.
| void Thyra::DefaultInverseLinearOp< Scalar >::initialize | ( | const Teuchos::RCP< const LinearOpWithSolveBase< Scalar > > & | lows, | |
| const SolveCriteria< Scalar > * | fwdSolveCriteria = NULL, |
|||
| const EThrowOnSolveFailure | throwOnFwdSolveFailure = THROW_ON_SOLVE_FAILURE, |
|||
| const SolveCriteria< Scalar > * | adjSolveCriteria = NULL, |
|||
| const EThrowOnSolveFailure | throwOnAdjSolveFailure = THROW_ON_SOLVE_FAILURE | |||
| ) |
Initialize given a non-const LinearOpWithSolveBase object and an optional .
| lows | [in] The LinearOpWithSolveBase object that will solve(...) and/or solveTranspose(...) will be called on. Note that *this may give up non-const views of *lows so that *lows may be changed through clients of this object. | |
| fwdSolveCriteria | [in] The criteria used to call lows->solve(...). If fwdSolveCriteria==NULL then the default solve criteria built into *lows | |
| adjSolveCriteria | |
lows.get() != NULL
Postconditions:
Definition at line 99 of file Thyra_DefaultInverseLinearOp.hpp.
| void Thyra::DefaultInverseLinearOp< Scalar >::uninitialize | ( | ) |
Set to uninitialized.
Postconditions:
Definition at line 115 of file Thyra_DefaultInverseLinearOp.hpp.
| bool Thyra::DefaultInverseLinearOp< Scalar >::isLowsConst | ( | ) | const |
| Teuchos::RCP< LinearOpWithSolveBase< Scalar > > Thyra::DefaultInverseLinearOp< Scalar >::getNonconstLows | ( | ) |
| Teuchos::RCP< const LinearOpWithSolveBase< Scalar > > Thyra::DefaultInverseLinearOp< Scalar >::getLows | ( | ) | const |
| Teuchos::RCP< const VectorSpaceBase< Scalar > > Thyra::DefaultInverseLinearOp< Scalar >::range | ( | ) | const |
Returns this->getLows()->domain() if <t>this->getLows().get()!=NULL and returns Teuchos::null otherwise.
Definition at line 154 of file Thyra_DefaultInverseLinearOp.hpp.
| Teuchos::RCP< const VectorSpaceBase< Scalar > > Thyra::DefaultInverseLinearOp< Scalar >::domain | ( | ) | const |
Returns this->getLows()->range() if <t>this->getLows().get()!=NULL and returns Teuchos::null otherwise.
Definition at line 163 of file Thyra_DefaultInverseLinearOp.hpp.
| Teuchos::RCP< const LinearOpBase< Scalar > > Thyra::DefaultInverseLinearOp< Scalar >::clone | ( | ) | const |
| std::string Thyra::DefaultInverseLinearOp< Scalar >::description | ( | ) | const |
| void Thyra::DefaultInverseLinearOp< Scalar >::describe | ( | Teuchos::FancyOStream & | out, | |
| const Teuchos::EVerbosityLevel | verbLevel | |||
| ) | const |
| bool Thyra::DefaultInverseLinearOp< Scalar >::opSupported | ( | EOpTransp | M_trans | ) | const [protected] |
Returns true only if all constituent operators support M_trans.
Definition at line 254 of file Thyra_DefaultInverseLinearOp.hpp.
| void Thyra::DefaultInverseLinearOp< Scalar >::apply | ( | const EOpTransp | M_trans, | |
| const MultiVectorBase< Scalar > & | X, | |||
| MultiVectorBase< Scalar > * | Y, | |||
| const Scalar | alpha, | |||
| const Scalar | beta | |||
| ) | const [protected] |
| Teuchos::RCP< LinearOpBase< Scalar > > nonconstInverse | ( | const Teuchos::RCP< LinearOpWithSolveBase< Scalar > > & | A, | |
| const SolveCriteria< Scalar > * | fwdSolveCriteria = NULL, |
|||
| const EThrowOnSolveFailure | throwOnFwdSolveFailure = THROW_ON_SOLVE_FAILURE, |
|||
| const SolveCriteria< Scalar > * | adjSolveCriteria = NULL, |
|||
| const EThrowOnSolveFailure | throwOnAdjSolveFailure = THROW_ON_SOLVE_FAILURE | |||
| ) | [related] |
Form a non-const implicit inverse operator <tt>M = inv(A).
Definition at line 365 of file Thyra_DefaultInverseLinearOp.hpp.
| Teuchos::RCP< LinearOpBase< Scalar > > inverse | ( | const Teuchos::RCP< const LinearOpWithSolveBase< Scalar > > & | A, | |
| const SolveCriteria< Scalar > * | fwdSolveCriteria = NULL, |
|||
| const EThrowOnSolveFailure | throwOnFwdSolveFailure = THROW_ON_SOLVE_FAILURE, |
|||
| const SolveCriteria< Scalar > * | adjSolveCriteria = NULL, |
|||
| const EThrowOnSolveFailure | throwOnAdjSolveFailure = THROW_ON_SOLVE_FAILURE | |||
| ) | [related] |
Form a const implicit inverse operator <tt>M = inv(A).
Definition at line 383 of file Thyra_DefaultInverseLinearOp.hpp.
1.4.7