42 #ifndef THYRA_DEFAULT_PRODUCT_MULTI_VECTOR_DEF_HPP 43 #define THYRA_DEFAULT_PRODUCT_MULTI_VECTOR_DEF_HPP 45 #include "Thyra_DefaultProductMultiVector_decl.hpp" 46 #include "Thyra_DefaultProductVectorSpace.hpp" 47 #include "Thyra_DefaultProductVector.hpp" 48 #include "Thyra_AssertOp.hpp" 57 template<
class Scalar>
63 template<
class Scalar>
70 TEUCHOS_TEST_FOR_EXCEPT( is_null(productSpace_in) );
71 TEUCHOS_TEST_FOR_EXCEPT( numMembers <= 0 );
73 Array<RCP<MultiVectorBase<Scalar> > > multiVecs;
74 const int numBlocks = productSpace_in->numBlocks();
75 for (
int k = 0; k < numBlocks; ++k )
76 multiVecs.push_back(createMembers(productSpace_in->getBlock(k),numMembers));
81 template<
class Scalar>
87 initializeImpl(productSpace_in,multiVecs);
91 template<
class Scalar>
97 initializeImpl(productSpace_in,multiVecs);
101 template<
class Scalar>
104 productSpace_ = Teuchos::null;
105 multiVecs_.resize(0);
113 template<
class Scalar>
116 std::ostringstream oss;
118 << Teuchos::Describable::description()
120 <<
"rangeDim="<<this->range()->dim()
121 <<
",domainDim="<<this->domain()->dim()
122 <<
",numBlocks = "<<numBlocks_
128 template<
class Scalar>
130 FancyOStream &out_arg,
131 const Teuchos::EVerbosityLevel verbLevel
134 using Teuchos::OSTab;
135 using Teuchos::describe;
136 if (verbLevel == Teuchos::VERB_NONE)
138 RCP<FancyOStream> out = rcp(&out_arg,
false);
141 case Teuchos::VERB_NONE:
143 case Teuchos::VERB_DEFAULT:
144 case Teuchos::VERB_LOW:
145 *out << this->description() << std::endl;
147 case Teuchos::VERB_MEDIUM:
148 case Teuchos::VERB_HIGH:
149 case Teuchos::VERB_EXTREME:
152 << Teuchos::Describable::description() <<
"{" 153 <<
"rangeDim="<<this->range()->dim()
154 <<
",domainDim="<<this->domain()->dim()
158 <<
"numBlocks="<< numBlocks_ << std::endl
159 <<
"Constituent multi-vector objects V[0], V[1], ... V[numBlocks-1]:\n";
161 for(
int k = 0; k < numBlocks_; ++k ) {
162 *out <<
"V["<<k<<
"] = " 163 << Teuchos::describe(*multiVecs_[k].getConstObj(),verbLevel);
168 TEUCHOS_TEST_FOR_EXCEPT(
true);
176 template<
class Scalar>
177 RCP<const ProductVectorSpaceBase<Scalar> >
180 return productSpace_;
184 template<
class Scalar>
187 return multiVecs_[k].isConst();
191 template<
class Scalar>
192 RCP<MultiVectorBase<Scalar> >
195 return multiVecs_[k].getNonconstObj();
199 template<
class Scalar>
200 RCP<const MultiVectorBase<Scalar> >
203 return multiVecs_[k].getConstObj();
210 template<
class Scalar>
211 RCP<MultiVectorBase<Scalar> >
215 Array<RCP<MultiVectorBase<Scalar> > > blocks;
216 for (
int k = 0; k < numBlocks_; ++k )
217 blocks.push_back(multiVecs_[k].getConstObj()->clone_mv());
218 return defaultProductMultiVector<Scalar>(productSpace_, blocks());
225 template<
class Scalar>
226 RCP< const VectorSpaceBase<Scalar> >
229 return productSpace_;
233 template<
class Scalar>
234 RCP< const VectorSpaceBase<Scalar> >
237 if (is_null(productSpace_))
238 return Teuchos::null;
239 return multiVecs_[0].getConstObj()->domain();
249 template<
class Scalar>
252 for (
int k = 0; k < numBlocks_; ++k ) {
253 multiVecs_[k].getNonconstObj()->assign(alpha);
258 template<
class Scalar>
264 TEUCHOS_ASSERT_EQUALITY(this->domain()->dim(), mv.
domain()->dim());
265 TEUCHOS_ASSERT(productSpace_->isCompatible(*mv.
range()));
269 const RCP<const ProductMultiVectorBase<Scalar> > pv
272 for (
int k = 0; k < numBlocks_; ++k) {
273 multiVecs_[k].getNonconstObj()->
assign(*pv->getMultiVectorBlock(k));
281 template<
class Scalar>
284 for (
int k = 0; k < numBlocks_; ++k) {
285 multiVecs_[k].getNonconstObj()->scale(alpha);
290 template<
class Scalar>
297 TEUCHOS_ASSERT_EQUALITY(this->domain()->dim(), mv.
domain()->dim());
298 TEUCHOS_ASSERT(productSpace_->isCompatible(*mv.
range()));
302 const RCP<const ProductMultiVectorBase<Scalar> > pv
305 for (
int k = 0; k < numBlocks_; ++k) {
306 multiVecs_[k].getNonconstObj()->
update(alpha, *pv->getMultiVectorBlock(k));
314 template<
class Scalar>
316 const ArrayView<const Scalar>& alpha,
322 TEUCHOS_ASSERT_EQUALITY(alpha.size(), mv.size());
323 for (
Ordinal i = 0; i < mv.size(); ++i) {
324 TEUCHOS_ASSERT_EQUALITY(this->domain()->dim(), mv[i]->domain()->dim());
325 TEUCHOS_ASSERT(productSpace_->isCompatible(*mv[i]->range()));
330 bool allCastsSuccessful =
true;
331 Array<Ptr<const ProductMultiVectorBase<Scalar> > > pvs(mv.size());
332 for (
Ordinal i = 0; i < mv.size(); ++i) {
334 if (pvs[i].is_null()) {
335 allCastsSuccessful =
false;
340 if (allCastsSuccessful) {
341 Array<RCP<const MultiVectorBase<Scalar> > > blocks_rcp(pvs.size());
342 Array<Ptr<const MultiVectorBase<Scalar> > > blocks(pvs.size());
343 for (
int k = 0; k < numBlocks_; ++k) {
344 for (
Ordinal i = 0; i < pvs.size(); ++i) {
346 blocks[i] = blocks_rcp[i].ptr();
348 multiVecs_[k].getNonconstObj()->linear_combination(alpha, blocks(), beta);
356 template<
class Scalar>
359 const ArrayView<Scalar>& prods
363 TEUCHOS_ASSERT_EQUALITY(this->domain()->dim(), mv.
domain()->dim());
364 TEUCHOS_ASSERT_EQUALITY(this->domain()->dim(), prods.size());
365 TEUCHOS_ASSERT(productSpace_->isCompatible(*mv.
range()));
368 const RCP<const ProductMultiVectorBase<Scalar> > pv
371 for (
Ordinal i = 0; i < prods.size(); ++i)
372 prods[i] = ScalarTraits<Scalar>::zero();
374 Array<Scalar> subProds(prods.size());
375 for (
int k = 0; k < numBlocks_; ++k) {
376 multiVecs_[k].getConstObj()->
dots(*pv->getMultiVectorBlock(k), subProds());
377 for (
Ordinal i = 0; i < prods.size(); ++i) {
378 prods[i] += subProds[i];
387 template<
class Scalar>
389 const ArrayView<
typename ScalarTraits<Scalar>::magnitudeType>& norms
393 TEUCHOS_ASSERT_EQUALITY(this->domain()->dim(), norms.size());
395 typedef ScalarTraits<Scalar> ST;
396 for (
Ordinal i = 0; i < norms.size(); ++i)
397 norms[i] = ST::magnitude(ST::zero());
399 Array<typename ST::magnitudeType> subNorms(norms.size());
400 for (
int k = 0; k < numBlocks_; ++k) {
401 multiVecs_[k].getConstObj()->norms_1(subNorms());
402 for (
Ordinal i = 0; i < norms.size(); ++i) {
403 norms[i] += subNorms[i];
409 template<
class Scalar>
411 const ArrayView<
typename ScalarTraits<Scalar>::magnitudeType>& norms
415 TEUCHOS_ASSERT_EQUALITY(this->domain()->dim(), norms.size());
417 typedef ScalarTraits<Scalar> ST;
418 for (
Ordinal i = 0; i < norms.size(); ++i)
419 norms[i] = ST::magnitude(ST::zero());
421 Array<typename ST::magnitudeType> subNorms(norms.size());
422 for (
int k = 0; k < numBlocks_; ++k) {
423 multiVecs_[k].getConstObj()->norms_2(subNorms());
424 for (
Ordinal i = 0; i < norms.size(); ++i) {
425 norms[i] += subNorms[i]*subNorms[i];
429 for (
Ordinal i = 0; i < norms.size(); ++i) {
430 norms[i] = ST::magnitude(ST::squareroot(norms[i]));
435 template<
class Scalar>
437 const ArrayView<
typename ScalarTraits<Scalar>::magnitudeType>& norms
441 TEUCHOS_ASSERT_EQUALITY(this->domain()->dim(), norms.size());
443 typedef ScalarTraits<Scalar> ST;
444 for (
Ordinal i = 0; i < norms.size(); ++i)
445 norms[i] = ST::magnitude(ST::zero());
447 Array<typename ST::magnitudeType> subNorms(norms.size());
448 for (
int k = 0; k < numBlocks_; ++k) {
449 multiVecs_[k].getConstObj()->norms_inf(subNorms());
450 for (
Ordinal i = 0; i < norms.size(); ++i) {
451 if (subNorms[i] > norms[i])
452 norms[i] = subNorms[i];
458 template<
class Scalar>
459 RCP<const VectorBase<Scalar> >
463 Array<RCP<const VectorBase<Scalar> > > cols_;
464 for (
int k = 0; k < numBlocks_; ++k )
465 cols_.push_back(multiVecs_[k].getConstObj()->col(j));
466 return defaultProductVector<Scalar>(productSpace_, cols_());
470 template<
class Scalar>
471 RCP<VectorBase<Scalar> >
475 Array<RCP<VectorBase<Scalar> > > cols_;
476 for (
int k = 0; k < numBlocks_; ++k )
477 cols_.push_back(multiVecs_[k].getNonconstObj()->col(j));
478 return defaultProductVector<Scalar>(productSpace_, cols_());
482 template<
class Scalar>
483 RCP<const MultiVectorBase<Scalar> >
487 Array<RCP<const MultiVectorBase<Scalar> > > blocks;
488 for (
int k = 0; k < numBlocks_; ++k )
489 blocks.push_back(multiVecs_[k].getConstObj()->subView(colRng));
490 return defaultProductMultiVector<Scalar>(productSpace_, blocks());
494 template<
class Scalar>
495 RCP<MultiVectorBase<Scalar> >
499 Array<RCP<MultiVectorBase<Scalar> > > blocks;
500 for (
int k = 0; k < numBlocks_; ++k )
501 blocks.push_back(multiVecs_[k].getNonconstObj()->subView(colRng));
502 return defaultProductMultiVector<Scalar>(productSpace_, blocks());
506 template<
class Scalar>
507 RCP<const MultiVectorBase<Scalar> >
509 const ArrayView<const int> &cols
513 Array<RCP<const MultiVectorBase<Scalar> > > blocks;
514 for (
int k = 0; k < numBlocks_; ++k )
515 blocks.push_back(multiVecs_[k].getConstObj()->subView(cols));
516 return defaultProductMultiVector<Scalar>(productSpace_, blocks());
520 template<
class Scalar>
521 RCP<MultiVectorBase<Scalar> >
523 const ArrayView<const int> &cols
527 Array<RCP<MultiVectorBase<Scalar> > > blocks;
528 for (
int k = 0; k < numBlocks_; ++k )
529 blocks.push_back(multiVecs_[k].getNonconstObj()->subView(cols));
530 return defaultProductMultiVector<Scalar>(productSpace_, blocks());
534 template<
class Scalar>
536 const RTOpPack::RTOpT<Scalar> &primary_op,
539 const ArrayView<
const Ptr<RTOpPack::ReductTarget> > &reduct_objs,
540 const Ordinal primary_global_offset_in
544 using Teuchos::ptr_dynamic_cast;
545 using Thyra::applyOp;
550 for (
int j = 0; j < multi_vecs_in.size(); ++j ) {
552 "DefaultProductMultiVector<Scalar>::mvMultiReductApplyOpImpl(...)",
553 *this->range(), *multi_vecs_in[j]->range()
556 "DefaultProductMultiVector<Scalar>::mvMultiReductApplyOpImpl(...)",
557 *this->domain(), *multi_vecs_in[j]->domain()
560 for (
int j = 0; j < targ_multi_vecs_inout.size(); ++j ) {
562 "DefaultProductMultiVector<Scalar>::mvMultiReductApplyOpImpl(...)",
563 *this->range(), *targ_multi_vecs_inout[j]->range()
566 "DefaultProductMultiVector<Scalar>::mvMultiReductApplyOpImpl(...)",
567 *this->domain(), *targ_multi_vecs_inout[j]->domain()
570 #endif // TEUCHOS_DEBUG 577 bool allProductMultiVectors =
true;
579 Array<Ptr<const ProductMultiVectorBase<Scalar> > > multi_vecs;
580 for (
int j = 0; j < multi_vecs_in.size() && allProductMultiVectors; ++j ) {
582 TEUCHOS_TEST_FOR_EXCEPT( is_null(multi_vecs_in[j]) );
584 const Ptr<const ProductMultiVectorBase<Scalar> >
588 if ( !is_null(multi_vecs_j) ) {
589 multi_vecs.push_back(multi_vecs_j);
592 allProductMultiVectors =
false;
596 Array<Ptr<ProductMultiVectorBase<Scalar> > > targ_multi_vecs;
597 for (
int j = 0; j < targ_multi_vecs_inout.size() && allProductMultiVectors; ++j )
600 TEUCHOS_TEST_FOR_EXCEPT( is_null(targ_multi_vecs_inout[j]) );
602 Ptr<ProductMultiVectorBase<Scalar> >
604 targ_multi_vecs_inout[j]
606 if (!is_null(targ_multi_vecs_j)) {
607 targ_multi_vecs.push_back(targ_multi_vecs_j);
610 allProductMultiVectors =
false;
618 if ( allProductMultiVectors ) {
627 Array<RCP<const MultiVectorBase<Scalar> > >
628 multi_vecs_rcp_block_k(multi_vecs_in.size());
629 Array<Ptr<const MultiVectorBase<Scalar> > >
630 multi_vecs_block_k(multi_vecs_in.size());
631 Array<RCP<MultiVectorBase<Scalar> > >
632 targ_multi_vecs_rcp_block_k(targ_multi_vecs_inout.size());
633 Array<Ptr<MultiVectorBase<Scalar> > >
634 targ_multi_vecs_block_k(targ_multi_vecs_inout.size());
636 Ordinal g_off = primary_global_offset_in;
638 for (
int k = 0; k < numBlocks_; ++k ) {
640 const Ordinal dim_k = productSpace_->getBlock(k)->dim();
644 for (
int j = 0; j < multi_vecs_in.size(); ++j ) {
645 RCP<const MultiVectorBase<Scalar> > multi_vecs_rcp_block_k_j =
647 multi_vecs_rcp_block_k[j] = multi_vecs_rcp_block_k_j;
648 multi_vecs_block_k[j] = multi_vecs_rcp_block_k_j.ptr();
651 for (
int j = 0; j < targ_multi_vecs_inout.size(); ++j ) {
652 RCP<MultiVectorBase<Scalar> > targ_multi_vecs_rcp_block_k_j =
653 targ_multi_vecs[j]->getNonconstMultiVectorBlock(k);
654 targ_multi_vecs_rcp_block_k[j] = targ_multi_vecs_rcp_block_k_j;
655 targ_multi_vecs_block_k[j] = targ_multi_vecs_rcp_block_k_j.ptr();
660 Thyra::applyOp<Scalar>(
661 primary_op, multi_vecs_block_k(), targ_multi_vecs_block_k(),
678 primary_op, multi_vecs_in(), targ_multi_vecs_inout(),
679 reduct_objs, primary_global_offset_in);
686 template<
class Scalar>
690 RTOpPack::ConstSubMultiVectorView<Scalar> *sub_mv
694 rowRng, colRng, sub_mv );
699 template<
class Scalar>
701 RTOpPack::ConstSubMultiVectorView<Scalar>* sub_mv
710 template<
class Scalar>
714 RTOpPack::SubMultiVectorView<Scalar> *sub_mv
718 rowRng,colRng,sub_mv );
723 template<
class Scalar>
725 RTOpPack::SubMultiVectorView<Scalar>* sub_mv
736 template<
class Scalar>
743 template<
class Scalar>
753 typedef Teuchos::ScalarTraits<Scalar> ST;
754 using Teuchos::dyn_cast;
759 "DefaultProductMultiVector<Scalar>::apply(...)",
760 *
this, M_trans, X_in, &*Y_inout );
773 for (
int k = 0; k < numBlocks_; ++k ) {
775 *multiVecs_[k].getConstObj(), M_trans,
790 for (
int k = 0; k < numBlocks_; ++k ) {
791 RCP<const MultiVectorBase<Scalar> >
792 M_k = multiVecs_[k].getConstObj(),
795 Thyra::apply( *M_k, M_trans, *X_k, Y_inout.ptr(), alpha, beta );
798 Thyra::apply( *M_k, M_trans, *X_k, Y_inout.ptr(), alpha, ST::one() );
808 template<
class Scalar>
809 template<
class MultiVectorType>
812 const ArrayView<
const RCP<MultiVectorType> > &multiVecs
819 TEUCHOS_ASSERT(nonnull(productSpace_in));
820 TEUCHOS_ASSERT_EQUALITY(multiVecs.size(), productSpace_in->numBlocks());
821 #endif // TEUCHOS_DEBUG 822 const RCP<const VectorSpaceBase<Scalar> >
823 theDomain = multiVecs[0]->domain();
824 const int numBlocks = productSpace_in->numBlocks();
826 for (
int k = 0; k < numBlocks; ++k ) {
829 *theDomain, *multiVecs[k]->domain()
833 productSpace_ = productSpace_in;
834 numBlocks_ = numBlocks;
835 multiVecs_.assign(multiVecs.begin(),multiVecs.end());
842 template<
class Scalar>
843 void DefaultProductMultiVector<Scalar>::assertInitialized()
const 845 TEUCHOS_TEST_FOR_EXCEPTION(
846 is_null(productSpace_), std::logic_error,
847 "Error, this DefaultProductMultiVector object is not intialized!" 852 template<
class Scalar>
853 void DefaultProductMultiVector<Scalar>::validateColIndex(
const int j)
const 856 const int domainDim = multiVecs_[0].getConstObj()->domain()->dim();
857 TEUCHOS_TEST_FOR_EXCEPTION(
858 ! ( 0 <= j && j < domainDim ), std::logic_error,
859 "Error, the column index j = " << j <<
" does not fall in the range [0,"<<domainDim<<
"]!" 864 #endif // TEUCHOS_DEBUG 870 template<
class Scalar>
871 Teuchos::RCP<Thyra::DefaultProductMultiVector<Scalar> >
872 Thyra::defaultProductMultiVector()
874 return Teuchos::rcp(
new DefaultProductMultiVector<Scalar>);
878 template<
class Scalar>
879 Teuchos::RCP<Thyra::DefaultProductMultiVector<Scalar> >
880 Thyra::defaultProductMultiVector(
881 const RCP<
const DefaultProductVectorSpace<Scalar> > &productSpace,
885 RCP<DefaultProductMultiVector<Scalar> > pmv = defaultProductMultiVector<Scalar>();
886 pmv->initialize(productSpace, numMembers);
891 template<
class Scalar>
892 Teuchos::RCP<Thyra::DefaultProductMultiVector<Scalar> >
893 Thyra::defaultProductMultiVector(
894 const RCP<
const DefaultProductVectorSpace<Scalar> > &productSpace,
895 const ArrayView<
const RCP<MultiVectorBase<Scalar> > > &multiVecs
898 const RCP<DefaultProductMultiVector<Scalar> > pmv =
899 defaultProductMultiVector<Scalar>();
900 pmv->initialize(productSpace, multiVecs);
905 template<
class Scalar>
906 Teuchos::RCP<Thyra::DefaultProductMultiVector<Scalar> >
907 Thyra::defaultProductMultiVector(
908 const RCP<
const DefaultProductVectorSpace<Scalar> > &productSpace,
909 const ArrayView<
const RCP<
const MultiVectorBase<Scalar> > > &multiVecs
912 const RCP<DefaultProductMultiVector<Scalar> > pmv =
913 defaultProductMultiVector<Scalar>();
914 pmv->initialize(productSpace, multiVecs);
919 template<
class Scalar>
920 Teuchos::RCP<const Thyra::ProductMultiVectorBase<Scalar> >
921 Thyra::castOrCreateSingleBlockProductMultiVector(
922 const RCP<
const DefaultProductVectorSpace<Scalar> > &productSpace,
923 const RCP<
const MultiVectorBase<Scalar> > &mv
926 const RCP<const ProductMultiVectorBase<Scalar> > pmv =
927 Teuchos::rcp_dynamic_cast<
const ProductMultiVectorBase<Scalar> >(mv);
930 return defaultProductMultiVector<Scalar>(productSpace, Teuchos::tuple(mv)());
934 template<
class Scalar>
935 Teuchos::RCP<Thyra::ProductMultiVectorBase<Scalar> >
936 Thyra::nonconstCastOrCreateSingleBlockProductMultiVector(
937 const RCP<
const DefaultProductVectorSpace<Scalar> > &productSpace,
938 const RCP<MultiVectorBase<Scalar> > &mv
941 const RCP<ProductMultiVectorBase<Scalar> > pmv =
942 Teuchos::rcp_dynamic_cast<ProductMultiVectorBase<Scalar> >(mv);
945 return defaultProductMultiVector<Scalar>(productSpace, Teuchos::tuple(mv)());
956 #define THYRA_DEFAULT_PRODUCT_MULTI_VECTOR_INSTANT(SCALAR) \ 958 template class DefaultProductMultiVector<SCALAR >; \ 960 template RCP<DefaultProductMultiVector<SCALAR > > \ 961 defaultProductMultiVector<SCALAR >(); \ 964 template RCP<DefaultProductMultiVector<SCALAR > > \ 965 defaultProductMultiVector( \ 966 const RCP<const DefaultProductVectorSpace<SCALAR > > &productSpace, \ 967 const int numMembers \ 971 template RCP<DefaultProductMultiVector<SCALAR > > \ 972 defaultProductMultiVector( \ 973 const RCP<const DefaultProductVectorSpace<SCALAR > > &productSpace, \ 974 const ArrayView<const RCP<MultiVectorBase<SCALAR > > > &multiVecs \ 978 template RCP<DefaultProductMultiVector<SCALAR > > \ 979 defaultProductMultiVector( \ 980 const RCP<const DefaultProductVectorSpace<SCALAR > > &productSpace, \ 981 const ArrayView<const RCP<const MultiVectorBase<SCALAR > > > &multiVecs \ 985 template RCP<const ProductMultiVectorBase<SCALAR > > \ 986 castOrCreateSingleBlockProductMultiVector( \ 987 const RCP<const DefaultProductVectorSpace<SCALAR > > &productSpace, \ 988 const RCP<const MultiVectorBase<SCALAR > > &mv \ 992 template RCP<ProductMultiVectorBase<SCALAR > > \ 993 nonconstCastOrCreateSingleBlockProductMultiVector( \ 994 const RCP<const DefaultProductVectorSpace<SCALAR > > &productSpace, \ 995 const RCP<MultiVectorBase<SCALAR > > &mv \ 999 #endif // THYRA_DEFAULT_PRODUCT_MULTI_VECTOR_DEF_HPP void initialize(int *argc, char ***argv)
Base interface for product multi-vectors.
#define THYRA_ASSERT_VEC_SPACES(FUNC_NAME, VS1, VS2)
This is a very useful macro that should be used to validate that two vector spaces are compatible...
virtual void updateImpl(Scalar alpha, const MultiVectorBase< Scalar > &mv)
virtual void mvMultiReductApplyOpImpl(const RTOpPack::RTOpT< Scalar > &primary_op, const ArrayView< const Ptr< const MultiVectorBase< Scalar > > > &multi_vecs, const ArrayView< const Ptr< MultiVectorBase< Scalar > > > &targ_multi_vecs, const ArrayView< const Ptr< RTOpPack::ReductTarget > > &reduct_objs, const Ordinal primary_global_offset) const
virtual RCP< const VectorSpaceBase< Scalar > > range() const =0
Return a smart pointer for the range space for this operator.
EOpTransp
Enumeration for determining how a linear operator is applied. `*.
void releaseDetachedMultiVectorViewImpl(RTOpPack::ConstSubMultiVectorView< Scalar > *sub_mv) const
#define THYRA_ASSERT_LINEAR_OP_MULTIVEC_APPLY_SPACES(FUNC_NAME, M, M_T, X, Y)
This is a very useful macro that should be used to validate that the spaces for the multi-vector vers...
void mvMultiReductApplyOpImpl(const RTOpPack::RTOpT< Scalar > &primary_op, const ArrayView< const Ptr< const MultiVectorBase< Scalar > > > &multi_vecs, const ArrayView< const Ptr< MultiVectorBase< Scalar > > > &targ_multi_vecs, const ArrayView< const Ptr< RTOpPack::ReductTarget > > &reduct_objs, const Ordinal primary_global_offset) const
RCP< const MultiVectorBase< Scalar > > getMultiVectorBlock(const int k) const
virtual void acquireNonconstDetachedMultiVectorViewImpl(const Range1D &rowRng, const Range1D &colRng, RTOpPack::SubMultiVectorView< Scalar > *sub_mv)
RCP< const VectorBase< Scalar > > colImpl(Ordinal j) const
virtual void assignMultiVecImpl(const MultiVectorBase< Scalar > &mv)
Default implementation of assign(MV) using RTOps.
Use the non-transposed operator.
RCP< VectorBase< Scalar > > nonconstColImpl(Ordinal j)
virtual void linearCombinationImpl(const ArrayView< const Scalar > &alpha, const ArrayView< const Ptr< const MultiVectorBase< Scalar > > > &mv, const Scalar &beta)
Default implementation of linear_combination using RTOps.
virtual Teuchos::RCP< MultiVectorBase< Scalar > > getNonconstMultiVectorBlock(const int k)=0
Returns a non-persisting non-const view of the zero-based kth block multi-vector. ...
EOpTransp real_trans(EOpTransp transp)
Return NOTRANS or TRANS for real scalar valued operators and this also is used for determining struct...
RCP< const MultiVectorBase< Scalar > > contigSubViewImpl(const Range1D &colRng) const
RCP< const MultiVectorBase< Scalar > > nonContigSubViewImpl(const ArrayView< const int > &cols) const
virtual void norms1Impl(const ArrayView< typename ScalarTraits< Scalar >::magnitudeType > &norms) const
void applyImpl(const EOpTransp M_trans, const MultiVectorBase< Scalar > &X, const Ptr< MultiVectorBase< Scalar > > &Y, const Scalar alpha, const Scalar beta) const
virtual void norms2Impl(const ArrayView< typename ScalarTraits< Scalar >::magnitudeType > &norms) const
virtual Teuchos::RCP< const MultiVectorBase< Scalar > > getMultiVectorBlock(const int k) const =0
Returns a non-persisting const view of the (zero-based) kth block multi-vector.
std::string description() const
virtual void releaseDetachedMultiVectorViewImpl(RTOpPack::ConstSubMultiVectorView< Scalar > *sub_mv) const
RCP< MultiVectorBase< Scalar > > getNonconstMultiVectorBlock(const int k)
Teuchos::Ordinal Ordinal
Type for the dimension of a vector space. `*.
void acquireNonconstDetachedMultiVectorViewImpl(const Range1D &rowRng, const Range1D &colRng, RTOpPack::SubMultiVectorView< Scalar > *sub_mv)
virtual void normsInfImpl(const ArrayView< typename ScalarTraits< Scalar >::magnitudeType > &norms) const
RCP< const ProductVectorSpaceBase< Scalar > > productSpace() const
Interface for a collection of column vectors called a multi-vector.
RCP< MultiVectorBase< Scalar > > nonconstContigSubViewImpl(const Range1D &colRng)
virtual void acquireDetachedMultiVectorViewImpl(const Range1D &rowRng, const Range1D &colRng, RTOpPack::ConstSubMultiVectorView< Scalar > *sub_mv) const
virtual void dotsImpl(const MultiVectorBase< Scalar > &mv, const ArrayView< Scalar > &prods) const
Default implementation of dots using RTOps.
Concrete implementation of a product multi-vector.
virtual void linearCombinationImpl(const ArrayView< const Scalar > &alpha, const ArrayView< const Ptr< const MultiVectorBase< Scalar > > > &mv, const Scalar &beta)
virtual void assignMultiVecImpl(const MultiVectorBase< Scalar > &mv)
bool opSupportedImpl(EOpTransp M_trans) const
RCP< MultiVectorBase< Scalar > > clone_mv() const
void update(Scalar alpha, const MultiVectorBase< Scalar > &mv)
virtual void commitNonconstDetachedMultiVectorViewImpl(RTOpPack::SubMultiVectorView< Scalar > *sub_mv)
void dots(const MultiVectorBase< Scalar > &mv, const ArrayView< Scalar > &prods) const
Column-wise Euclidean dot product.
void describe(Teuchos::FancyOStream &out, const Teuchos::EVerbosityLevel verbLevel) const
RCP< const VectorSpaceBase< Scalar > > range() const
bool blockIsConst(const int k) const
virtual void dotsImpl(const MultiVectorBase< Scalar > &mv, const ArrayView< Scalar > &prods) const
void assign(Scalar alpha)
V = alpha.
virtual RCP< const VectorSpaceBase< Scalar > > domain() const =0
Return a smart pointer for the domain space for this operator.
void acquireDetachedMultiVectorViewImpl(const Range1D &rowRng, const Range1D &colRng, RTOpPack::ConstSubMultiVectorView< Scalar > *sub_mv) const
void commitNonconstDetachedMultiVectorViewImpl(RTOpPack::SubMultiVectorView< Scalar > *sub_mv)
void initialize(const RCP< const DefaultProductVectorSpace< Scalar > > &productSpace, const int numMembers)
RCP< const VectorSpaceBase< Scalar > > domain() const
void uninitialize()
Uninitialize.
virtual void assignImpl(Scalar alpha)
RCP< MultiVectorBase< Scalar > > nonconstNonContigSubViewImpl(const ArrayView< const int > &cols)
DefaultProductMultiVector()
Construct to uninitialized.
virtual void scaleImpl(Scalar alpha)
virtual void updateImpl(Scalar alpha, const MultiVectorBase< Scalar > &mv)
Default implementation of update using RTOps.