Finite Element Domain Decomposition Library
FEDDLib
Loading...
Searching...
No Matches
MultiVector_def.hpp
1#ifndef MULTIVECTOR_DEF_hpp
2#define MULTIVECTOR_DEF_hpp
3#include "MultiVector_decl.hpp"
4#include "BlockMultiVector_decl.hpp"
5
14
15namespace FEDD {
16
17template <class SC, class LO, class GO, class NO>
18MultiVector<SC,LO,GO,NO>::MultiVector():
19multiVector_(),
20map_(),
21importer_(),
22exporter_()
23{
24
25}
26
27
28template <class SC, class LO, class GO, class NO>
29MultiVector<SC,LO,GO,NO>::MultiVector( MapConstPtr_Type map, UN nmbVectors ):
30multiVector_( ),
31map_(map),
32importer_(),
33exporter_()
34{
35 multiVector_ = Teuchos::RCP( new TpetraMultiVector_Type( map->getTpetraMap(), nmbVectors ));
36}
37
38template <class SC, class LO, class GO, class NO>
39MultiVector<SC,LO,GO,NO>::MultiVector( TpetraMultiVectorPtr_Type& tpetraMVPtrIn ):
40multiVector_( tpetraMVPtrIn ),
41map_(),
42importer_(),
43exporter_()
44{
45 map_.reset( new Map_Type( tpetraMVPtrIn->getMap() ) );
46}
47
48template <class SC, class LO, class GO, class NO>
49MultiVector<SC,LO,GO,NO>::MultiVector( MultiVectorConstPtr_Type mvIn ):
50multiVector_( ),
51map_(),
52importer_(),
53exporter_()
54{
55 multiVector_ =Teuchos::RCP( new TpetraMultiVector_Type( mvIn->getMap()->getTpetraMap(), mvIn->getNumVectors() ));
56 map_.reset( new Map_Type( *mvIn->getMap() ) );
57 for (UN j=0; j<this->getNumVectors(); j++) {
58 Teuchos::ArrayRCP< const SC > valuesIn = mvIn->getData(j);
59 Teuchos::ArrayRCP< SC > valuesThis = this->getDataNonConst(j);
60 for (UN i=0; i<valuesThis.size(); i++)//can this be quicker?
61 valuesThis[i] = valuesIn[i];
62 }
63}
64
65template <class SC, class LO, class GO, class NO>
69
70template <class SC, class LO, class GO, class NO>
71typename MultiVector<SC,LO,GO,NO>::MapConstPtr_Type MultiVector<SC,LO,GO,NO>::getMap() const{
72 return map_;
73}
74
75template <class SC, class LO, class GO, class NO>
76typename MultiVector<SC,LO,GO,NO>::MapPtr_Type MultiVector<SC,LO,GO,NO>::getMapNonConst() {
77 return Teuchos::rcp_const_cast<Map_Type>( map_ );
78}
79
80template <class SC, class LO, class GO, class NO>
81typename MultiVector<SC,LO,GO,NO>::TpetraMapConstPtr_Type MultiVector<SC,LO,GO,NO>::getMapTpetra() const{
82 TEUCHOS_TEST_FOR_EXCEPTION(multiVector_.is_null(),std::runtime_error,"RCP<MultiVector> is null.")
83
84 return multiVector_->getMap();
85}
86
87// checking whether multivector is null
88template <class SC, class LO, class GO, class NO>
90 return multiVector_.is_null();
91}
92
93template <class SC, class LO, class GO, class NO>
94void MultiVector<SC,LO,GO,NO>::replaceGlobalValue (GO globalRow, UN vectorIndex, const SC &value){
95 multiVector_->replaceGlobalValue( globalRow, vectorIndex, value );
96}
97
98template <class SC, class LO, class GO, class NO>
99void MultiVector<SC,LO,GO,NO>::replaceLocalValue (LO localRow, UN vectorIndex, const SC &value){
100 multiVector_->replaceLocalValue( localRow, vectorIndex, value );
101}
103template <class SC, class LO, class GO, class NO>
104void MultiVector<SC,LO,GO,NO>::sumIntoGlobalValue (GO globalRow, UN vectorIndex, const SC &value){
105 multiVector_->sumIntoGlobalValue( globalRow, vectorIndex, value );
106}
107
108template <class SC, class LO, class GO, class NO>
109LO MultiVector<SC,LO,GO,NO>::getLocalLength() const{
110 return multiVector_->getLocalLength();
111}
112
113template <class SC, class LO, class GO, class NO>
114Teuchos::ArrayRCP< const SC > MultiVector<SC,LO,GO,NO>::getData(UN i) const{
115 return multiVector_->getData(i);
116}
117
118template <class SC, class LO, class GO, class NO>
119Teuchos::ArrayRCP< SC > MultiVector<SC,LO,GO,NO>::getDataNonConst(UN i) const{
120 return multiVector_->getDataNonConst(i);
121}
122
124template <class SC, class LO, class GO, class NO>
126 return multiVector_->getNumVectors();
128
129template <class SC, class LO, class GO, class NO>
130typename MultiVector<SC,LO,GO,NO>::TpetraMultiVectorConstPtr_Type MultiVector<SC,LO,GO,NO>::getTpetraMultiVector() const{
131 return multiVector_;
132}
133
134template <class SC, class LO, class GO, class NO>
135typename MultiVector<SC,LO,GO,NO>::TpetraMultiVectorPtr_Type MultiVector<SC,LO,GO,NO>::getTpetraMultiVectorNonConst() {
136 return multiVector_;
137}
138
139template <class SC, class LO, class GO, class NO>
140void MultiVector<SC,LO,GO,NO>::print(Teuchos::EVerbosityLevel verbLevel) const{
141
142 Teuchos::RCP<Teuchos::FancyOStream> out = Teuchos::VerboseObjectBase::getDefaultOStream();
143 multiVector_->describe(*out,verbLevel);
144}
145
146template <class SC, class LO, class GO, class NO>
147Teuchos::RCP<Thyra::MultiVectorBase<SC> > MultiVector<SC,LO,GO,NO>::getThyraMultiVector( ) {
148 // Teuchos::RCP<Thyra::MultiVectorBase<SC> > mv = Teuchos::rcp_const_cast<Thyra::MultiVectorBase<SC> >(Xpetra::ThyraUtils<SC,LO,GO,NO>::toThyraMultiVector(multiVector_));
149
150 auto thyTpMap = Thyra::tpetraVectorSpace<SC,LO,GO,NO>(multiVector_->getMap()); //Thyra::tpetraVectorSpace<SC,LO,GO,NO>(Teuchos::rcp_dynamic_cast<const TpetraMap_Type>(multiVector_->getMap())->getTpetraMap());
151 Teuchos::RCP<Tpetra::MultiVector<SC,LO,GO,NO>> tpMV = multiVector_;
152 auto thyDomMap =Thyra::tpetraVectorSpace<SC,LO,GO,NO>(Tpetra::createLocalMapWithNode<LO,GO,NO>(multiVector_->getNumVectors(), multiVector_->getMap()->getComm()));
153 auto thyMV = rcp(new Thyra::TpetraMultiVector<SC,LO,GO,NO>());
154 thyMV->initialize(thyTpMap, thyDomMap, tpMV);
155
156 return thyMV;
157}
159
160template <class SC, class LO, class GO, class NO>
161Teuchos::RCP<const Thyra::MultiVectorBase<SC> > MultiVector<SC,LO,GO,NO>::getThyraMultiVectorConst( ) const{
162
163 //Teuchos::RCP<Thyra::MultiVectorBase<SC> > mv;
164 //return Xpetra::ThyraUtils<SC,LO,GO,NO>::toThyraMultiVector( multiVector_ );
165 auto thyTpMap = Thyra::tpetraVectorSpace<SC,LO,GO,NO>(multiVector_->getMap()); //Thyra::tpetraVectorSpace<SC,LO,GO,NO>(Teuchos::rcp_dynamic_cast<const TpetraMap_Type>(multiVector_->getMap())->getTpetraMap());
166 Teuchos::RCP<Tpetra::MultiVector<SC,LO,GO,NO>> tpMV = multiVector_;
167 auto thyDomMap =Thyra::tpetraVectorSpace<SC,LO,GO,NO>(Tpetra::createLocalMapWithNode<LO,GO,NO>(multiVector_->getNumVectors(), multiVector_->getMap()->getComm()));
168 auto thyMV = rcp(new Thyra::TpetraMultiVector<SC,LO,GO,NO>());
169 thyMV->initialize(thyTpMap, thyDomMap, tpMV);
171 return thyMV;
172}
174template <class SC, class LO, class GO, class NO>
175void MultiVector<SC,LO,GO,NO>::fromThyraMultiVector( Teuchos::RCP< Thyra::MultiVectorBase<SC> > thyraMV){
177 typedef Thyra::TpetraOperatorVectorExtraction<SC,LO,GO,NO> TOVE_Type;
178
179 Teuchos::RCP<TpetraMultiVector_Type> tMV = TOVE_Type::getTpetraMultiVector( thyraMV );
180 multiVector_ = tMV;
181}
182
183template <class SC, class LO, class GO, class NO>
184void MultiVector<SC,LO,GO,NO>::norm2(const Teuchos::ArrayView< typename Teuchos::ScalarTraits<SC>::magnitudeType> &norms) const {
185 TEUCHOS_TEST_FOR_EXCEPTION( multiVector_.is_null(), std::runtime_error,"MultiVector in norm2 is null.")
186 multiVector_->norm2(norms);
187}
188
189// Inf Norm of Multivector
190template <class SC, class LO, class GO, class NO>
191void MultiVector<SC,LO,GO,NO>::normInf(const Teuchos::ArrayView< typename Teuchos::ScalarTraits<SC>::magnitudeType> &normsInf) const {
192 TEUCHOS_TEST_FOR_EXCEPTION( multiVector_.is_null(), std::runtime_error,"MultiVector in normInf is null.")
193 multiVector_->normInf(normsInf);
194
195}
196
197template <class SC, class LO, class GO, class NO>
198void MultiVector<SC,LO,GO,NO>::abs(MultiVectorConstPtr_Type a) {
199 TEUCHOS_TEST_FOR_EXCEPTION( multiVector_.is_null(), std::runtime_error,"MultiVector in abs is null.")
200 multiVector_->abs( *a->getTpetraMultiVector());
201}
202
203template <class SC, class LO, class GO, class NO>
204void MultiVector<SC,LO,GO,NO>::dot(MultiVectorConstPtr_Type a, const Teuchos::ArrayView< typename Teuchos::ScalarTraits<SC>::magnitudeType> &dots) const {
205 TEUCHOS_TEST_FOR_EXCEPTION( multiVector_.is_null(), std::runtime_error,"MultiVector in dot is null.")
206 multiVector_->dot( *a->getTpetraMultiVector(), dots );
207}
208
209template <class SC, class LO, class GO, class NO>
210void MultiVector<SC,LO,GO,NO>::update( const SC& alpha, const MultiVector_Type& A, const SC& beta) {
211 TEUCHOS_TEST_FOR_EXCEPTION( getNumVectors() != A.getNumVectors(), std::logic_error,"MultiVectors for update have different number of vectors.")
212 multiVector_->update( alpha, *A.getTpetraMultiVector(), beta );
213}
214
215template <class SC, class LO, class GO, class NO>
216void MultiVector<SC,LO,GO,NO>::update( const SC& alpha, const MultiVector_Type& A, const SC& beta , const MultiVector_Type& B, const SC& gamma) {
217 TEUCHOS_TEST_FOR_EXCEPTION( getNumVectors() != A.getNumVectors(), std::logic_error,"MultiVectors for update have different number of vectors.")
218
219 multiVector_->update( alpha, *A.getTpetraMultiVector(), beta, *B.getTpetraMultiVector(), gamma );
220
221}
222
223template <class SC, class LO, class GO, class NO>
224void MultiVector<SC,LO,GO,NO>::putScalar( const SC& alpha ){
225 multiVector_->putScalar( alpha );
226}
227
228template <class SC, class LO, class GO, class NO>
229void MultiVector<SC,LO,GO,NO>::scale( const SC& alpha ){
230 multiVector_->scale( alpha );
231}
232
233template <class SC, class LO, class GO, class NO>
234void MultiVector<SC,LO,GO,NO>::multiply(Teuchos::ETransp transA, Teuchos::ETransp transB, const SC &alpha, MultiVectorConstPtr_Type &A, MultiVectorConstPtr_Type &B, const SC &beta){
235 multiVector_->multiply( transA, transB, alpha, *A->getTpetraMultiVector(), *B->getTpetraMultiVector(), beta );
236}
237template <class SC, class LO, class GO, class NO>
238void MultiVector<SC,LO,GO,NO>::multiply(Teuchos::ETransp transA, Teuchos::ETransp transB, const SC &alpha, BlockMultiVectorConstPtr_Type &A, BlockMultiVectorConstPtr_Type &B, const SC &beta){
239// if (this->getMap()->getCommNonConst()->getRank()==0)
240// std::cout << "### For testing purposes only." << std::endl;
241
242 for (int i=0; i<A->size(); i++){
243 MultiVectorConstPtr_Type a = A->getBlock(i);
244 MultiVectorConstPtr_Type b = B->getBlock(i);
245 if ( i==0 )
246 this->multiply( transA, transB, alpha, a, b, beta );
247 else
248 this->multiply( transA, transB, alpha, a, b, Teuchos::ScalarTraits<SC>::one() );
249 }
250
251}
252
253template <class SC, class LO, class GO, class NO>
254void MultiVector<SC,LO,GO,NO>::importFromVector( MultiVectorConstPtr_Type mvIn, bool reuseImport, std::string combineMode, std::string type) {
255
256 TEUCHOS_TEST_FOR_EXCEPTION( getNumVectors() != mvIn->getNumVectors(), std::logic_error,"MultiVectors for fillFromVector have different number of vectors.")
257
258 if ( importer_.is_null() || !reuseImport) {
259 if (type=="Forward")
260 importer_ = Teuchos::RCP(new Tpetra::Import<LO, GO, NO>(mvIn->getMapTpetra(), this->getMapTpetra() ));
261 else if(type=="Reverse")
262 importer_ = Teuchos::RCP(new Tpetra::Import<LO, GO, NO>(this->getMapTpetra(), mvIn->getMapTpetra() ));
263 else
264 TEUCHOS_TEST_FOR_EXCEPTION( true, std::logic_error,"Unknown type for import. Choose Forward or Reverse")
265 }
266 else{
267 TEUCHOS_TEST_FOR_EXCEPTION( !importer_->getSourceMap()->isSameAs( *mvIn->getMap()->getTpetraMap() ), std::logic_error,"Source maps of Importer and Multivector are not the same.")
268 TEUCHOS_TEST_FOR_EXCEPTION( !importer_->getTargetMap()->isSameAs( *this->getMap()->getTpetraMap() ), std::logic_error,"Target maps of Importer and Multivector are not the same.")
269 }
270
271
272 if (type=="Forward") {
273 if ( !combineMode.compare("Insert") )
274 multiVector_->doImport ( *mvIn->getTpetraMultiVector(), *importer_, Tpetra::INSERT);
275 else if ( !combineMode.compare("Add") )
276 multiVector_->doImport ( *mvIn->getTpetraMultiVector(), *importer_, Tpetra::ADD);
277 else
278 TEUCHOS_TEST_FOR_EXCEPTION( true, std::logic_error,"Unknown combine mode.")
279 }
280 else if(type=="Reverse"){
281 if ( !combineMode.compare("Insert") )
282 multiVector_->doExport ( *mvIn->getTpetraMultiVector(), *importer_, Tpetra::INSERT);
283 else if ( !combineMode.compare("Add") )
284 multiVector_->doExport ( *mvIn->getTpetraMultiVector(), *importer_, Tpetra::ADD);
285 else
286 TEUCHOS_TEST_FOR_EXCEPTION( true, std::logic_error,"Unknown combine mode.")
287 }
288 else
289 TEUCHOS_TEST_FOR_EXCEPTION( true, std::logic_error,"Unknown type for import. Choose Forward or Reverse")
290}
291
292template <class SC, class LO, class GO, class NO>
293void MultiVector<SC,LO,GO,NO>::exportFromVector( MultiVectorConstPtr_Type mvIn, bool reuseExport, std::string combineMode, std::string type) {
294 TEUCHOS_TEST_FOR_EXCEPTION( getNumVectors() != mvIn->getNumVectors(), std::logic_error,"MultiVectors for exportToVector have different number of vectors.")
295
296 if ( exporter_.is_null() || !reuseExport) {
297 if (type=="Forward")
298 exporter_ = Teuchos::RCP(new Tpetra::Export<LO, GO, NO>(mvIn->getMapTpetra(), this->getMapTpetra() ));
299 else if(type=="Reverse")
300 exporter_ = Teuchos::RCP(new Tpetra::Export<LO, GO, NO>(this->getMapTpetra(), mvIn->getMapTpetra() ));
301 else
302 TEUCHOS_TEST_FOR_EXCEPTION( true, std::logic_error,"Unknown type for export. Choose Forward or Reverse")
303 }
304 else{
305 TEUCHOS_TEST_FOR_EXCEPTION( !exporter_->getSourceMap()->isSameAs( *this->getMap()->getTpetraMap() ), std::logic_error,"Source maps of Exporter and Multivector are not the same.")
306 TEUCHOS_TEST_FOR_EXCEPTION( !exporter_->getTargetMap()->isSameAs( *mvIn->getMap()->getTpetraMap() ), std::logic_error,"Target maps of Exporter and Multivector are not the same.")
307 }
308 if (type=="Forward") {
309 if ( !combineMode.compare("Insert") )
310 multiVector_->doExport ( *mvIn->getTpetraMultiVector(), *exporter_, Tpetra::INSERT);
311 else if ( !combineMode.compare("Add") )
312 multiVector_->doExport ( *mvIn->getTpetraMultiVector(), *exporter_, Tpetra::ADD);
313 else
314 TEUCHOS_TEST_FOR_EXCEPTION( true, std::logic_error,"Unknown combine mode.")
315 }
316 else if (type=="Reverse") {
317 if ( !combineMode.compare("Insert") )
318 multiVector_->doImport ( *mvIn->getTpetraMultiVector(), *exporter_, Tpetra::INSERT);
319 else if ( !combineMode.compare("Add") )
320 multiVector_->doImport ( *mvIn->getTpetraMultiVector(), *exporter_, Tpetra::ADD);
321 else
322 TEUCHOS_TEST_FOR_EXCEPTION( true, std::logic_error,"Unknown combine mode.")
323 }
324 else
325 TEUCHOS_TEST_FOR_EXCEPTION( true, std::logic_error,"Unknown type for export. Choose Forward or Reverse")
326}
327
328template <class SC, class LO, class GO, class NO>
329void MultiVector<SC,LO,GO,NO>::writeMM(std::string fileName) const{
330 TEUCHOS_TEST_FOR_EXCEPTION( multiVector_.is_null(), std::runtime_error,"MultiVector in writeMM is null.")
331
332 typedef Tpetra::CrsMatrix<SC,LO,GO,NO> TpetraCrsMatrix;
333
334 /*typedef Tpetra::MultiVector<SC,LO,GO,NO> TpetraMultiVector;
335 typedef Teuchos::RCP<TpetraMultiVector> TpetraMultiVectorPtr;
336
337 const Xpetra::TpetraMultiVector<SC,LO,GO,NO>& xTpetraMultiVector = dynamic_cast<const Xpetra::TpetraMultiVector<SC,LO,GO,NO> &>(*multiVector_);
338
339 TpetraMultiVectorPtr tpetraMultiVector = xTpetraMultiVector.getTpetra_MultiVector();*/
340
341 Tpetra::MatrixMarket::Writer< TpetraCrsMatrix > tpetraWriter;
342
343 tpetraWriter.writeDenseFile(fileName, multiVector_, "multivector", "");
344}
345
346
347template <class SC, class LO, class GO, class NO>
348void MultiVector<SC,LO,GO,NO>::readMM(std::string fileName) const{
349 TEUCHOS_TEST_FOR_EXCEPTION( multiVector_.is_null(), std::runtime_error,"MultiVector in writeMM is null.")
350
351 typedef Tpetra::CrsMatrix<SC,LO,GO,NO> TpetraCrsMatrix;
352 typedef Teuchos::RCP<TpetraCrsMatrix> TpetraCrsMatrixPtr;
353
354 typedef Tpetra::MultiVector<SC,LO,GO,NO> TpetraMultiVector;
355 typedef Teuchos::RCP<TpetraMultiVector> TpetraMultiVectorPtr;
356
357 typedef Tpetra::Map<LO,GO,NO> TpetraMap;
358 typedef Teuchos::RCP<TpetraMap> TpetraMapPtr;
359
360 Teuchos::RCP<Teuchos::FancyOStream> out = Teuchos::VerboseObjectBase::getDefaultOStream();
361
362 // Xpetra::TpetraMultiVector<SC,LO,GO,NO>& xTpetraMultiVector = dynamic_cast<Xpetra::TpetraMultiVector<SC,LO,GO,NO> &>(*multiVector_);
363 TpetraMultiVectorPtr tpetraMultiVector = multiVector_; //xTpetraMultiVector.getTpetra_MultiVector();
364
365 Teuchos::RCP<const Tpetra::Map<LO,GO,NO> > tpetraMap = tpetraMultiVector->getMap();
366
367 Tpetra::MatrixMarket::Reader< TpetraCrsMatrix > tpetraReader;
368
369 tpetraMultiVector = tpetraReader.readDenseFile(fileName, multiVector_->getMap()->getComm() ,tpetraMap);
370
371 for (UN j=0; j<this->getNumVectors(); j++) {
372 Teuchos::ArrayRCP< const SC > valuesIn = tpetraMultiVector->getData(j);
373 Teuchos::ArrayRCP< SC > valuesThis = this->getDataNonConst(j);
374 for (UN i=0; i<valuesThis.size(); i++)//can this be quicker?
375 valuesThis[i] = valuesIn[i];
376 }
377
378 //multiVector_->describe(*out,Teuchos::VERB_EXTREME);
379}
380
381
382template <class SC, class LO, class GO, class NO>
383typename MultiVector<SC,LO,GO,NO>::MultiVectorConstPtr_Type MultiVector<SC,LO,GO,NO>::getVector( int i ) const{
384
385 TpetraMultiVectorConstPtr_Type tpetraMV = multiVector_->getVector( i );
386 TpetraMultiVectorPtr_Type tpetraMVNonConst = Teuchos::rcp_const_cast<TpetraMultiVector_Type>( tpetraMV );
387 MultiVectorConstPtr_Type singleMV = Teuchos::rcp( new const MultiVector_Type ( tpetraMVNonConst ) );
388 return singleMV;
389
390}
391
392template <class SC, class LO, class GO, class NO>
393typename MultiVector<SC,LO,GO,NO>::MultiVectorPtr_Type MultiVector<SC,LO,GO,NO>::sumColumns() const{
394
395 MultiVectorPtr_Type sumMV = Teuchos::rcp( new MultiVector_Type ( map_, 1 ) );
396 sumMV->putScalar(0.);
397 for (int i=0; i<this->getNumVectors(); i++)
398 sumMV->getTpetraMultiVectorNonConst()->getVectorNonConst(0)->update( 1., *multiVector_->getVector(i), 1. );
399
400 return sumMV;
401}
402
403template <class SC, class LO, class GO, class NO>
404SC MultiVector<SC,LO,GO,NO>::getMax() const{
405 TEUCHOS_TEST_FOR_EXCEPTION( this->getNumVectors() > 1, std::runtime_error, "numMultiVector>1: max function not implemented!")
406 return multiVector_->getVector(0)->normInf();
407}
408
409//typename MultiVector<SC,LO,GO,NO>::ThyraLinOpPtr_Type MultiVector<SC,LO,GO,NO>::getThyraLinOp(){
410//
411// return ;
412//}
413
414}
415#endif
Definition Map_decl.hpp:36
Definition MultiVector_decl.hpp:33
void replaceLocalValue(LO localRow, UN vectorIndex, const SC &value)
Definition MultiVector_def.hpp:99
Teuchos::ArrayRCP< const SC > getData(UN i) const
Get data of multivector.
Definition MultiVector_def.hpp:114
Teuchos::ArrayRCP< SC > getDataNonConst(UN i) const
Get data of multivector.
Definition MultiVector_def.hpp:119
bool is_null() const
checking whether the multiVector exists
Definition MultiVector_def.hpp:89
MapPtr_Type getMapNonConst()
Return non constant version of underlying map.
Definition MultiVector_def.hpp:76
MapConstPtr_Type getMap() const
Return underlying map.
Definition MultiVector_def.hpp:71
TpetraMapConstPtr_Type getMapTpetra() const
Return direct tpetra map of underlying map.
Definition MultiVector_def.hpp:81
void replaceGlobalValue(GO globalRow, UN vectorIndex, const SC &value)
Replace global value in mv.
Definition MultiVector_def.hpp:94
void sumIntoGlobalValue(GO globalRow, UN vectorIndex, const SC &value)
Update (+=) a value in host memory, using global row index.
Definition MultiVector_def.hpp:104
~MultiVector()
Destructor.
Definition MultiVector_def.hpp:66
UN getNumVectors() const
Get number of multivector (columns)
Definition MultiVector_def.hpp:125
void print(Teuchos::EVerbosityLevel verbLevel=Teuchos::VERB_EXTREME) const
Printing mv. Depending on verbosity level, output increases.
Definition MultiVector_def.hpp:140
Adaptive Mesh Refinement.
Definition AdaptiveMeshRefinement_decl.hpp:33