Thyra
Version of the Day
|
Concrete composite LinearOpBase
subclass that creates an implicitly added linear operator out of one or more constituent LinearOpBase
objects.
More...
#include <Thyra_DefaultAddedLinearOp_decl.hpp>
Related Functions | |
(Note that these are not member functions.) | |
template<class Scalar > | |
RCP< LinearOpBase< Scalar > > | nonconstAdd (const RCP< LinearOpBase< Scalar > > &A, const RCP< LinearOpBase< Scalar > > &B, const std::string &label="") |
Form an implicit addition of two linear operators: M = A + B . More... | |
template<class Scalar > | |
RCP< const LinearOpBase< Scalar > > | add (const RCP< const LinearOpBase< Scalar > > &A, const RCP< const LinearOpBase< Scalar > > &B, const std::string &label="") |
Form an implicit addition of two linear operators: M = A + B . More... | |
template<class Scalar > | |
RCP< LinearOpBase< Scalar > > | nonconstSubtract (const RCP< LinearOpBase< Scalar > > &A, const RCP< LinearOpBase< Scalar > > &B, const std::string &label="") |
Form an implicit subtraction of two linear operators: M = A - B . More... | |
template<class Scalar > | |
RCP< const LinearOpBase< Scalar > > | subtract (const RCP< const LinearOpBase< Scalar > > &A, const RCP< const LinearOpBase< Scalar > > &B, const std::string &label="") |
Form an implicit subtraction of two linear operators: M = A - B . More... | |
Related Functions inherited from Thyra::LinearOpBase< Scalar > | |
template<class Scalar > | |
bool | isFullyUninitialized (const LinearOpBase< Scalar > &M) |
Determines if a linear operator is in the "Fully Uninitialized" state or not. More... | |
template<class Scalar > | |
bool | isPartiallyInitialized (const LinearOpBase< Scalar > &M) |
Determines if a linear operator is in the "Partially Initialized" state or not. More... | |
template<class Scalar > | |
bool | isFullyInitialized (const LinearOpBase< Scalar > &M) |
Determines if a linear operator is in the "Fully Initialized" state or not. More... | |
template<class Scalar > | |
bool | opSupported (const LinearOpBase< Scalar > &M, EOpTransp M_trans) |
Determines if an operation is supported for a single scalar type. More... | |
template<class Scalar > | |
void | apply (const LinearOpBase< Scalar > &M, const EOpTransp M_trans, const MultiVectorBase< Scalar > &X, const Ptr< MultiVectorBase< Scalar > > &Y, const Scalar alpha=static_cast< Scalar >(1.0), const Scalar beta=static_cast< Scalar >(0.0)) |
Non-member function call for M.apply(...) . More... | |
void | apply (const LinearOpBase< double > &M, const EOpTransp M_trans, const MultiVectorBase< double > &X, const Ptr< MultiVectorBase< double > > &Y, const double alpha=1.0, const double beta=0.0) |
Calls apply<double>(...) . More... | |
Constructors/initializers/accessors | |
DefaultAddedLinearOp () | |
Constructs to uninitialized. More... | |
DefaultAddedLinearOp (const ArrayView< const RCP< LinearOpBase< Scalar > > > &Ops) | |
DefaultAddedLinearOp (const ArrayView< const RCP< const LinearOpBase< Scalar > > > &Ops) | |
void | initialize (const ArrayView< const RCP< LinearOpBase< Scalar > > > &Ops) |
Initialize given a list of non-const linear operators. More... | |
void | initialize (const ArrayView< const RCP< const LinearOpBase< Scalar > > > &Ops) |
Initialize given a list of const linear operators. More... | |
void | uninitialize () |
Set to uninitialized. More... | |
Overridden from AddedLinearOpBase | |
int | numOps () const |
bool | opIsConst (const int k) const |
RCP< LinearOpBase< Scalar > > | getNonconstOp (const int k) |
RCP< const LinearOpBase< Scalar > > | getOp (const int k) const |
Overridden from LinearOpBase | |
RCP< const VectorSpaceBase < Scalar > > | range () const |
Returns this->getOp(0).range() if <t>this->numOps() > 0 and returns Teuchos::null otherwise. More... | |
RCP< const VectorSpaceBase < Scalar > > | domain () const |
Returns this->getOp(this->numOps()-1).domain() if <t>this->numOps() > 0 and returns Teuchos::null otherwise. More... | |
RCP< const LinearOpBase< Scalar > > | clone () const |
bool | opSupportedImpl (EOpTransp M_trans) const |
Returns true only if all constituent operators support M_trans . More... | |
void | applyImpl (const EOpTransp M_trans, const MultiVectorBase< Scalar > &X, const Ptr< MultiVectorBase< Scalar > > &Y, const Scalar alpha, const Scalar beta) const |
Overridden from Teuchos::Describable | |
std::string | description () const |
Prints just the name DefaultAddedLinearOp along with the overall dimensions and the number of constituent operators. More... | |
void | describe (Teuchos::FancyOStream &out, const Teuchos::EVerbosityLevel verbLevel) const |
Prints the details about the constituent linear operators. More... | |
Concrete composite LinearOpBase
subclass that creates an implicitly added linear operator out of one or more constituent LinearOpBase
objects.
This class represents a added linear operator M
of the form:
M = Op[0] + Op[1] + ... + Op[numOps-1]
where Op[]
is an array of numOps
LinearOp
objects. Of course the operator M
is not constructed explicitly but instead just applies the constituent linear operators accordingly using temporaries.
In other words, this class defines apply()
as:
y = alpha*M*x + beta*y = alpha * ( Op[0]*x + Op[1]*x + ... * Op[numOps-1]*x ) + beta * y
Rather than calling the constructor directly, consider using the non-member helper functions described here.
Definition at line 85 of file Thyra_DefaultAddedLinearOp_decl.hpp.
Thyra::DefaultAddedLinearOp< Scalar >::DefaultAddedLinearOp | ( | ) |
Constructs to uninitialized.
Postconditions:
this->numOps()==0
Definition at line 95 of file Thyra_DefaultAddedLinearOp_def.hpp.
Thyra::DefaultAddedLinearOp< Scalar >::DefaultAddedLinearOp | ( | const ArrayView< const RCP< LinearOpBase< Scalar > > > & | Ops | ) |
Calls initialize()
.
Rather than calling this constructor directly, consider using the non-member helper functions described here.
Definition at line 100 of file Thyra_DefaultAddedLinearOp_def.hpp.
Thyra::DefaultAddedLinearOp< Scalar >::DefaultAddedLinearOp | ( | const ArrayView< const RCP< const LinearOpBase< Scalar > > > & | Ops | ) |
Calls initialize()
.
Rather than calling this constructor directly, consider using the non-member helper functions described here.
Definition at line 108 of file Thyra_DefaultAddedLinearOp_def.hpp.
void Thyra::DefaultAddedLinearOp< Scalar >::initialize | ( | const ArrayView< const RCP< LinearOpBase< Scalar > > > & | Ops | ) |
Initialize given a list of non-const linear operators.
Ops | [in] Array (length numOps ) of constituent linear operators and their aggregated default definitions of the non-transposed operator. |
Preconditions:
numOps > 0
Ops != NULL
Ops[k].op().get()!=NULL
, for k=0...numOps-1
Postconditions:
this->numOps()==numOps
this->getOp(k).op().get()==Ops[k].op().get()
, for k=0...numOps-1
Definition at line 116 of file Thyra_DefaultAddedLinearOp_def.hpp.
void Thyra::DefaultAddedLinearOp< Scalar >::initialize | ( | const ArrayView< const RCP< const LinearOpBase< Scalar > > > & | Ops | ) |
Initialize given a list of const linear operators.
numOps | [in] Number of constituent operators. |
Ops | [in] Array (length numOps ) of constituent linear operators and their aggregated default definitions of the non-transposed operator. |
Preconditions:
numOps > 0
Ops != NULL
Ops[k].op().get()!=NULL
, for k=0...numOps-1
Postconditions:
this->numOps()==numOps
this->getOp(k).op().get()==Ops[k].op().get()
, for k=0...numOps-1
Definition at line 129 of file Thyra_DefaultAddedLinearOp_def.hpp.
void Thyra::DefaultAddedLinearOp< Scalar >::uninitialize | ( | ) |
Set to uninitialized.
Postconditions:
this->numOps()==0
Definition at line 142 of file Thyra_DefaultAddedLinearOp_def.hpp.
|
virtual |
Implements Thyra::AddedLinearOpBase< Scalar >.
Definition at line 153 of file Thyra_DefaultAddedLinearOp_def.hpp.
|
virtual |
Implements Thyra::AddedLinearOpBase< Scalar >.
Definition at line 160 of file Thyra_DefaultAddedLinearOp_def.hpp.
|
virtual |
Implements Thyra::AddedLinearOpBase< Scalar >.
Definition at line 171 of file Thyra_DefaultAddedLinearOp_def.hpp.
|
virtual |
Implements Thyra::AddedLinearOpBase< Scalar >.
Definition at line 182 of file Thyra_DefaultAddedLinearOp_def.hpp.
|
virtual |
Returns this->getOp(0).range() if <t>this->numOps() > 0
and returns Teuchos::null
otherwise.
Implements Thyra::LinearOpBase< Scalar >.
Definition at line 196 of file Thyra_DefaultAddedLinearOp_def.hpp.
|
virtual |
Returns this->getOp(this->numOps()-1).domain()
if <t>this->numOps() > 0 and returns Teuchos::null
otherwise.
Implements Thyra::LinearOpBase< Scalar >.
Definition at line 207 of file Thyra_DefaultAddedLinearOp_def.hpp.
|
virtual |
Reimplemented from Thyra::LinearOpBase< Scalar >.
Definition at line 218 of file Thyra_DefaultAddedLinearOp_def.hpp.
|
virtual |
Prints just the name DefaultAddedLinearOp
along with the overall dimensions and the number of constituent operators.
Reimplemented from Teuchos::Describable.
Definition at line 228 of file Thyra_DefaultAddedLinearOp_def.hpp.
|
virtual |
Prints the details about the constituent linear operators.
This function outputs different levels of detail based on the value passed in for verbLevel
:
ToDo: Finish documentation!
Reimplemented from Teuchos::Describable.
Definition at line 239 of file Thyra_DefaultAddedLinearOp_def.hpp.
|
protectedvirtual |
Returns true
only if all constituent operators support M_trans
.
Implements Thyra::LinearOpBase< Scalar >.
Definition at line 282 of file Thyra_DefaultAddedLinearOp_def.hpp.
|
protectedvirtual |
Implements Thyra::LinearOpBase< Scalar >.
Definition at line 293 of file Thyra_DefaultAddedLinearOp_def.hpp.
|
related |
Form an implicit addition of two linear operators: M = A + B
.
|
related |
Form an implicit addition of two linear operators: M = A + B
.
|
related |
Form an implicit subtraction of two linear operators: M = A - B
.
|
related |
Form an implicit subtraction of two linear operators: M = A - B
.