42 #ifndef THYRA_DEFAULT_PRODUCT_VECTOR_DECL_HPP 43 #define THYRA_DEFAULT_PRODUCT_VECTOR_DECL_HPP 45 #include "Thyra_ProductVectorBase.hpp" 46 #include "Thyra_VectorDefaultBase.hpp" 47 #include "Teuchos_ConstNonconstObjectContainer.hpp" 48 #include "Teuchos_as.hpp" 55 template <
class Scalar>
class DefaultProductVectorSpace;
71 template<
class Scalar>
131 Teuchos::FancyOStream &out,
132 const Teuchos::EVerbosityLevel verbLevel
160 RCP<const ProductVectorSpaceBase<Scalar> >
productSpace()
const;
164 RCP<MultiVectorBase<Scalar> >
167 RCP<const MultiVectorBase<Scalar> >
176 RCP< const VectorSpaceBase<Scalar> >
space()
const;
190 const Ptr<RTOpPack::ReductTarget> &reduct_obj,
231 typedef Teuchos::ConstNonconstObjectContainer<VectorBase<Scalar> > CNVC;
236 RCP<const DefaultProductVectorSpace<Scalar> > productSpace_;
248 template<
class Scalar>
250 RCP<DefaultProductVector<Scalar> >
261 template<
class Scalar>
263 RCP<DefaultProductVector<Scalar> >
278 template<
class Scalar>
279 RCP<DefaultProductVector<Scalar> >
285 RCP<DefaultProductVector<Scalar> > pv = defaultProductVector<Scalar>();
286 pv->initialize(productSpace, vecs);
295 template<
class Scalar>
296 RCP<DefaultProductVector<Scalar> >
302 RCP<DefaultProductVector<Scalar> > pv = defaultProductVector<Scalar>();
303 pv->initialize(productSpace, vecs);
313 template<
class Scalar>
314 RCP<ProductVectorBase<Scalar> >
323 template<
class Scalar>
324 RCP<const ProductVectorBase<Scalar> >
331 #endif // THYRA_DEFAULT_PRODUCT_VECTOR_DECL_HPP void setSubVectorImpl(const RTOpPack::SparseSubVectorT< Scalar > &sub_vec)
void commitNonconstDetachedVectorViewImpl(RTOpPack::SubVectorView< Scalar > *sub_vec)
Base interface for product vectors.
RCP< DefaultProductVector< Scalar > > defaultProductVector(const RCP< const DefaultProductVectorSpace< Scalar > > &productSpace)
Nonmember constructor.
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
std::string description() const
RCP< const MultiVectorBase< Scalar > > getMultiVectorBlock(const int k) const
void uninitialize()
Uninitialize.
RCP< DefaultProductVector< Scalar > > defaultProductVector()
Nonmember constructor.
void setNonconstBlock(int i, const RCP< VectorBase< Scalar > > &b)
Convenient node subclass for concrete VectorBase subclasses that relies on a default MultiVectorBase ...
Teuchos::Ordinal Ordinal
Type for the dimension of a vector space. `*.
RCP< const ProductVectorSpaceBase< Scalar > > productSpace() const
DefaultProductVector()
Construct to uninitialized.
void acquireNonconstDetachedVectorViewImpl(const Range1D &rng, RTOpPack::SubVectorView< Scalar > *sub_vec)
bool blockIsConst(const int k) const
Abstract interface for finite-dimensional dense vectors.
RCP< const VectorBase< Scalar > > getVectorBlock(const int k) const
void releaseDetachedVectorViewImpl(RTOpPack::ConstSubVectorView< Scalar > *sub_vec) const
Concrete implementation of a product vector.
RCP< VectorBase< Scalar > > getNonconstVectorBlock(const int k)
RCP< const VectorSpaceBase< Scalar > > space() const
RCP< MultiVectorBase< Scalar > > getNonconstMultiVectorBlock(const int k)
RCP< DefaultProductVector< Scalar > > defaultProductVector(const RCP< const DefaultProductVectorSpace< Scalar > > &productSpace, const ArrayView< const RCP< const VectorBase< Scalar > > > &vecs)
Nonmember constructor.
RCP< DefaultProductVector< Scalar > > defaultProductVector(const RCP< const DefaultProductVectorSpace< Scalar > > &productSpace, const ArrayView< const RCP< VectorBase< Scalar > > > &vecs)
Nonmember constructor.
void describe(Teuchos::FancyOStream &out, const Teuchos::EVerbosityLevel verbLevel) const
void assignImpl(Scalar alpha)
void setBlock(int i, const RCP< const VectorBase< Scalar > > &b)
void acquireDetachedVectorViewImpl(const Range1D &rng, RTOpPack::ConstSubVectorView< Scalar > *sub_vec) const
void initialize(const RCP< const DefaultProductVectorSpace< Scalar > > &productSpace)
Initialize.