42 #ifndef THYRA_MULTI_VECTOR_PRODUCT_VECTOR_DECL_HPP 43 #define THYRA_MULTI_VECTOR_PRODUCT_VECTOR_DECL_HPP 46 #include "Thyra_ProductVectorBase.hpp" 47 #include "Thyra_VectorDefaultBase.hpp" 48 #include "Thyra_DefaultProductVector.hpp" 49 #include "Teuchos_ConstNonconstObjectContainer.hpp" 69 template<
class Scalar>
97 RCP<MultiVectorBase<Scalar> >
101 RCP<const MultiVectorBase<Scalar> >
117 Teuchos::FancyOStream &out,
118 const Teuchos::EVerbosityLevel verbLevel
127 RCP<VectorBase<Scalar> >
130 RCP<const VectorBase<Scalar> >
139 RCP<const ProductVectorSpaceBase<Scalar> >
144 RCP<MultiVectorBase<Scalar> >
147 RCP<const MultiVectorBase<Scalar> >
156 RCP< const VectorSpaceBase<Scalar> >
space()
const;
170 const Ptr<RTOpPack::ReductTarget> &reduct_obj,
209 typedef Teuchos::ConstNonconstObjectContainer<MultiVectorBase<Scalar> > CNMVC;
215 RCP<const DefaultMultiVectorProductVectorSpace<Scalar> > productSpace_;
221 RCP<const DefaultProductVector<Scalar> >
222 getDefaultProductVector()
const;
232 template<
class Scalar>
234 RCP<DefaultMultiVectorProductVector<Scalar> >
240 RCP<DefaultMultiVectorProductVector<Scalar> > multiVecProdVec
242 multiVecProdVec->initialize(productSpace,multiVec);
243 return multiVecProdVec;
252 template<
class Scalar>
254 RCP<const DefaultMultiVectorProductVector<Scalar> >
260 RCP<DefaultMultiVectorProductVector<Scalar> > multiVecProdVec
262 multiVecProdVec->initialize(productSpace,multiVec);
263 return multiVecProdVec;
276 template<
class Scalar>
278 RCP<DefaultMultiVectorProductVector<Scalar> >
284 TEUCHOS_TEST_FOR_EXCEPT(is_null(productSpace));
286 return multiVectorProductVector(
288 createMembers(productSpace->getBlock(0),productSpace->numBlocks())
296 #endif // THYRA_MULTI_VECTOR_PRODUCT_VECTOR_DECL_HPP void releaseDetachedVectorViewImpl(RTOpPack::ConstSubVectorView< Scalar > *sub_vec) const
Base interface for product vectors.
void assignImpl(Scalar alpha)
bool blockIsConst(const int k) const
void acquireDetachedVectorViewImpl(const Range1D &rng, RTOpPack::ConstSubVectorView< Scalar > *sub_vec) const
Concrete implementation of a product vector which is really composed out of the columns of a multi-ve...
RCP< const VectorSpaceBase< Scalar > > space() const
void commitNonconstDetachedVectorViewImpl(RTOpPack::SubVectorView< Scalar > *sub_vec)
RCP< const MultiVectorBase< Scalar > > getMultiVector() const
Convenient node subclass for concrete VectorBase subclasses that relies on a default MultiVectorBase ...
Teuchos::Ordinal Ordinal
Type for the dimension of a vector space. `*.
Interface for a collection of column vectors called a multi-vector.
RCP< DefaultMultiVectorProductVector< Scalar > > multiVectorProductVector(const RCP< const DefaultMultiVectorProductVectorSpace< Scalar > > &productSpace)
Nonmember constructor that creates a new uninitialized product vector represented underneath as a mul...
void acquireNonconstDetachedVectorViewImpl(const Range1D &rng, RTOpPack::SubVectorView< Scalar > *sub_vec)
Abstract interface for finite-dimensional dense vectors.
void describe(Teuchos::FancyOStream &out, const Teuchos::EVerbosityLevel verbLevel) const
Standard concrete implementation of a product vector space that creates product vectors fromed implic...
void initialize(const RCP< const DefaultMultiVectorProductVectorSpace< Scalar > > &productSpace, const RCP< MultiVectorBase< Scalar > > &multiVec)
Initialize with a non-const multi-vector.
void applyOpImpl(const RTOpPack::RTOpT< Scalar > &op, const ArrayView< const Ptr< const VectorBase< Scalar > > > &vecs, const ArrayView< const Ptr< VectorBase< Scalar > > > &targ_vecs, const Ptr< RTOpPack::ReductTarget > &reduct_obj, const Ordinal global_offset) const
DefaultMultiVectorProductVector()
Construct to uninitialized.
RCP< const DefaultMultiVectorProductVector< Scalar > > multiVectorProductVector(const RCP< const DefaultMultiVectorProductVectorSpace< Scalar > > &productSpace, const RCP< const MultiVectorBase< Scalar > > &multiVec)
Nonmember constructor that just wraps an existing const MultiVector as a const product vector...
std::string description() const
RCP< MultiVectorBase< Scalar > > getNonconstMultiVector()
RCP< const ProductVectorSpaceBase< Scalar > > productSpace() const
RCP< MultiVectorBase< Scalar > > getNonconstMultiVectorBlock(const int k)
RCP< DefaultMultiVectorProductVector< Scalar > > multiVectorProductVector(const RCP< const DefaultMultiVectorProductVectorSpace< Scalar > > &productSpace, const RCP< MultiVectorBase< Scalar > > &multiVec)
Nonmember constructor that just wraps an existing non-const MultiVector as a non-const product vector...
RCP< const MultiVectorBase< Scalar > > getMultiVectorBlock(const int k) const
RCP< VectorBase< Scalar > > getNonconstVectorBlock(const int k)
RCP< const VectorBase< Scalar > > getVectorBlock(const int k) const
void setSubVectorImpl(const RTOpPack::SparseSubVectorT< Scalar > &sub_vec)