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