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_DEFAULT_ZERO_LINEAR_OP_HPP
00030 #define THYRA_DEFAULT_ZERO_LINEAR_OP_HPP
00031
00032 #include "Thyra_DefaultZeroLinearOpDecl.hpp"
00033 #include "Thyra_VectorStdOps.hpp"
00034 #include "Teuchos_arrayArg.hpp"
00035
00036 namespace Thyra {
00037
00038
00039
00040 template<class Scalar>
00041 DefaultZeroLinearOp<Scalar>::DefaultZeroLinearOp()
00042 {}
00043
00044 template<class Scalar>
00045 DefaultZeroLinearOp<Scalar>::DefaultZeroLinearOp(
00046 const Teuchos::RCP<const VectorSpaceBase<Scalar> > &range
00047 ,const Teuchos::RCP<const VectorSpaceBase<Scalar> > &domain
00048 )
00049 {
00050 initialize(range,domain);
00051 }
00052
00053 template<class Scalar>
00054 void DefaultZeroLinearOp<Scalar>::initialize(
00055 const Teuchos::RCP<const VectorSpaceBase<Scalar> > &range
00056 ,const Teuchos::RCP<const VectorSpaceBase<Scalar> > &domain
00057 )
00058 {
00059 range_ = range.assert_not_null();
00060 domain_ = domain.assert_not_null();
00061 }
00062
00063 template<class Scalar>
00064 void DefaultZeroLinearOp<Scalar>::uninitialize()
00065 {
00066 range_ = Teuchos::null;
00067 domain_ = Teuchos::null;
00068 }
00069
00070
00071
00072 template<class Scalar>
00073 Teuchos::RCP< const VectorSpaceBase<Scalar> >
00074 DefaultZeroLinearOp<Scalar>::range() const
00075 {
00076 return range_;
00077 }
00078
00079 template<class Scalar>
00080 Teuchos::RCP< const VectorSpaceBase<Scalar> >
00081 DefaultZeroLinearOp<Scalar>::domain() const
00082 {
00083 return domain_;
00084 }
00085
00086 template<class Scalar>
00087 Teuchos::RCP<const LinearOpBase<Scalar> >
00088 DefaultZeroLinearOp<Scalar>::clone() const
00089 {
00090 typedef DefaultZeroLinearOp<Scalar> this_t;
00091 if(range_.get())
00092 return Teuchos::rcp(new this_t(range_,domain_));
00093 return Teuchos::rcp(new this_t());
00094 }
00095
00096
00097
00098 template<class Scalar>
00099 std::string DefaultZeroLinearOp<Scalar>::description() const
00100 {
00101 typedef Teuchos::ScalarTraits<Scalar> ST;
00102 std::ostringstream oss;
00103 oss
00104 << "Thyra::DefaultZeroLinearOp<" << ST::name() << ">{"
00105 << "range="<<(range_.get()?range_->description():"NULL")
00106 << ",domain="<<(domain_.get()?domain_->description():"NULL")
00107 << "}";
00108 return oss.str();
00109 }
00110
00111
00112
00113
00114
00115 template<class Scalar>
00116 bool DefaultZeroLinearOp<Scalar>::opSupported(ETransp M_trans) const
00117 {
00118 return true;
00119 }
00120
00121 template<class Scalar>
00122 void DefaultZeroLinearOp<Scalar>::apply(
00123 const ETransp M_trans
00124 ,const MultiVectorBase<Scalar> &X
00125 ,MultiVectorBase<Scalar> *Y
00126 ,const Scalar alpha
00127 ,const Scalar beta
00128 ) const
00129 {
00130 #ifdef TEUCHOS_DEBUG
00131 THYRA_ASSERT_LINEAR_OP_MULTIVEC_APPLY_SPACES(
00132 "DefaultZeroLinearOp<Scalar>::apply(...)",*this,M_trans,X,Y
00133 );
00134 #endif // TEUCHOS_DEBUG
00135 scale(beta,Y);
00136 }
00137
00138 }
00139
00140 template<class Scalar>
00141 Teuchos::RCP<const Thyra::LinearOpBase<Scalar> >
00142 Thyra::zero(
00143 const Teuchos::RCP<const VectorSpaceBase<Scalar> > &range
00144 ,const Teuchos::RCP<const VectorSpaceBase<Scalar> > &domain
00145 )
00146 {
00147 return Teuchos::rcp(new DefaultZeroLinearOp<Scalar>(range,domain));
00148 }
00149
00150 #endif // THYRA_DEFAULT_ZERO_LINEAR_OP_HPP