Xpetra Version of the Day
Loading...
Searching...
No Matches
Xpetra_TpetraCrsGraph_def.hpp
Go to the documentation of this file.
1// @HEADER
2// *****************************************************************************
3// Xpetra: A linear algebra interface package
4//
5// Copyright 2012 NTESS and the Xpetra contributors.
6// SPDX-License-Identifier: BSD-3-Clause
7// *****************************************************************************
8// @HEADER
9
10#ifndef XPETRA_TPETRACRSGRAPH_DEF_HPP
11#define XPETRA_TPETRACRSGRAPH_DEF_HPP
13#include "Xpetra_Exceptions.hpp"
14
15#include "Tpetra_CrsGraph.hpp"
16
17#include "Xpetra_CrsGraph.hpp"
19#include "Xpetra_Utils.hpp"
20#include "Xpetra_TpetraMap.hpp"
21#include "Xpetra_TpetraImport.hpp"
22#include "Xpetra_TpetraExport.hpp"
23
24namespace Xpetra {
25
26template <class LocalOrdinal, class GlobalOrdinal, class Node>
27TpetraCrsGraph<LocalOrdinal, GlobalOrdinal, Node>::TpetraCrsGraph(const RCP<const map_type> &rowMap, size_t maxNumEntriesPerRow, const RCP<ParameterList> &params)
28 : graph_(Teuchos::rcp(new Tpetra::CrsGraph<LocalOrdinal, GlobalOrdinal, Node>(toTpetra(rowMap), maxNumEntriesPerRow, params))) {}
29
30template <class LocalOrdinal, class GlobalOrdinal, class Node>
32 : graph_(Teuchos::rcp(new Tpetra::CrsGraph<LocalOrdinal, GlobalOrdinal, Node>(toTpetra(rowMap), NumEntriesPerRowToAlloc(), params))) {}
33
34template <class LocalOrdinal, class GlobalOrdinal, class Node>
35TpetraCrsGraph<LocalOrdinal, GlobalOrdinal, Node>::TpetraCrsGraph(const RCP<const Map> &rowMap, const RCP<const Map> &colMap, size_t maxNumEntriesPerRow, const RCP<ParameterList> &params)
36 : graph_(Teuchos::rcp(new Tpetra::CrsGraph<LocalOrdinal, GlobalOrdinal, Node>(toTpetra(rowMap), toTpetra(colMap), maxNumEntriesPerRow, params))) {}
37
38template <class LocalOrdinal, class GlobalOrdinal, class Node>
40 : graph_(Teuchos::rcp(new Tpetra::CrsGraph<LocalOrdinal, GlobalOrdinal, Node>(toTpetra(rowMap), toTpetra(colMap), NumEntriesPerRowToAlloc(), params))) {}
41
42template <class LocalOrdinal, class GlobalOrdinal, class Node>
45 const Import &importer,
46 const Teuchos::RCP<const Map> &domainMap,
47 const Teuchos::RCP<const Map> &rangeMap,
49 typedef Tpetra::CrsGraph<LocalOrdinal, GlobalOrdinal, Node> MyTpetraCrsGraph;
50 XPETRA_DYNAMIC_CAST(const TpetraCrsGraphClass, *sourceGraph, tSourceGraph, "Xpetra::TpetraCrsMatrix constructor only accepts Xpetra::TpetraCrsMatrix as the input argument."); // TODO: remove and use toTpetra()
51 RCP<const Tpetra::CrsGraph<LocalOrdinal, GlobalOrdinal, Node> > v = tSourceGraph.getTpetra_CrsGraph();
52
53 RCP<const Tpetra::Map<LocalOrdinal, GlobalOrdinal, Node> > myDomainMap = domainMap != Teuchos::null ? toTpetra(domainMap) : Teuchos::null;
54 RCP<const Tpetra::Map<LocalOrdinal, GlobalOrdinal, Node> > myRangeMap = rangeMap != Teuchos::null ? toTpetra(rangeMap) : Teuchos::null;
55 graph_ = Tpetra::importAndFillCompleteCrsGraph<MyTpetraCrsGraph>(v, toTpetra(importer), myDomainMap, myRangeMap, params);
56 bool restrictComm = false;
57 if (!params.is_null()) restrictComm = params->get("Restrict Communicator", restrictComm);
58 if (restrictComm && graph_->getRowMap().is_null()) graph_ = Teuchos::null;
59}
60
61template <class LocalOrdinal, class GlobalOrdinal, class Node>
64 const Teuchos::RCP<const Map> &colMap,
65 const typename local_graph_type::row_map_type &rowPointers,
66 const typename local_graph_type::entries_type::non_const_type &columnIndices,
68 : graph_(Teuchos::rcp(new Tpetra::CrsGraph<LocalOrdinal, GlobalOrdinal, Node>(toTpetra(rowMap), toTpetra(colMap), rowPointers, columnIndices, plist))) {}
69
70template <class LocalOrdinal, class GlobalOrdinal, class Node>
73 const Teuchos::RCP<const map_type> &colMap,
74 const local_graph_type &lclGraph,
76 : graph_(Teuchos::rcp(new Tpetra::CrsGraph<LocalOrdinal, GlobalOrdinal, Node>(toTpetra(rowMap), toTpetra(colMap), lclGraph, params))) {}
77
78template <class LocalOrdinal, class GlobalOrdinal, class Node>
80 TpetraCrsGraph(const local_graph_type &lclGraph,
81 const Teuchos::RCP<const map_type> &rowMap,
82 const Teuchos::RCP<const map_type> &colMap,
83 const Teuchos::RCP<const map_type> &domainMap,
84 const Teuchos::RCP<const map_type> &rangeMap,
86 : graph_(Teuchos::rcp(new Tpetra::CrsGraph<LocalOrdinal, GlobalOrdinal, Node>(lclGraph, toTpetra(rowMap), toTpetra(colMap), toTpetra(domainMap), toTpetra(rangeMap), params))) {}
87
88template <class LocalOrdinal, class GlobalOrdinal, class Node>
91 const Teuchos::RCP<const Map> &colMap,
92 const Teuchos::ArrayRCP<size_t> &rowPointers,
93 const Teuchos::ArrayRCP<LocalOrdinal> &columnIndices,
95 : graph_(Teuchos::rcp(new Tpetra::CrsGraph<LocalOrdinal, GlobalOrdinal, Node>(toTpetra(rowMap), toTpetra(colMap), rowPointers, columnIndices, params))) {}
96
97template <class LocalOrdinal, class GlobalOrdinal, class Node>
99
100template <class LocalOrdinal, class GlobalOrdinal, class Node>
102 XPETRA_MONITOR("TpetraCrsGraph::insertGlobalIndices");
103 graph_->insertGlobalIndices(globalRow, indices);
104}
105
106template <class LocalOrdinal, class GlobalOrdinal, class Node>
108 XPETRA_MONITOR("TpetraCrsGraph::insertLocalIndices");
109 graph_->insertLocalIndices(localRow, indices);
110}
111
112template <class LocalOrdinal, class GlobalOrdinal, class Node>
114 XPETRA_MONITOR("TpetraCrsGraph::removeLocalIndices");
115 graph_->removeLocalIndices(localRow);
116}
117
118template <class LocalOrdinal, class GlobalOrdinal, class Node>
120 allocateAllIndices(size_t numNonZeros, ArrayRCP<size_t> &rowptr, ArrayRCP<LocalOrdinal> &colind) {
121 rowptr.resize(getLocalNumRows() + 1);
122 colind.resize(numNonZeros);
123}
124
125template <class LocalOrdinal, class GlobalOrdinal, class Node>
127 setAllIndices(const ArrayRCP<size_t> &rowptr, const ArrayRCP<LocalOrdinal> &colind) {
128 graph_->setAllIndices(rowptr, colind);
129}
130
131template <class LocalOrdinal, class GlobalOrdinal, class Node>
134 rowptr = Kokkos::Compat::persistingView(graph_->getLocalRowPtrsHost());
135 colind = Kokkos::Compat::persistingView(graph_->getLocalIndicesHost());
136}
137
138template <class LocalOrdinal, class GlobalOrdinal, class Node>
140 XPETRA_MONITOR("TpetraCrsGraph::fillComplete");
141 graph_->fillComplete(toTpetra(domainMap), toTpetra(rangeMap), params);
142}
143
144template <class LocalOrdinal, class GlobalOrdinal, class Node>
146 XPETRA_MONITOR("TpetraCrsGraph::fillComplete");
147 graph_->fillComplete(params);
148}
149
150template <class LocalOrdinal, class GlobalOrdinal, class Node>
153 const Teuchos::RCP<const map_type> &rangeMap,
154 const Teuchos::RCP<const Import> &importer,
155 const Teuchos::RCP<const Export> &exporter,
157 XPETRA_MONITOR("TpetraCrsGraph::expertStaticFillComplete");
160
161 if (importer != Teuchos::null) {
162 XPETRA_DYNAMIC_CAST(const TpetraImportClass, *importer, tImporter, "Xpetra::TpetraCrsGraph::expertStaticFillComplete only accepts Xpetra::TpetraImport.");
163 myImport = tImporter.getTpetra_Import();
164 }
165 if (exporter != Teuchos::null) {
166 XPETRA_DYNAMIC_CAST(const TpetraExportClass, *exporter, tExporter, "Xpetra::TpetraCrsGraph::expertStaticFillComplete only accepts Xpetra::TpetraExport.");
167 myExport = tExporter.getTpetra_Export();
168 }
169
170 graph_->expertStaticFillComplete(toTpetra(domainMap), toTpetra(rangeMap), myImport, myExport, params);
171}
172
173template <class LocalOrdinal, class GlobalOrdinal, class Node>
175 XPETRA_MONITOR("TpetraCrsGraph::getComm");
176 return graph_->getComm();
177}
178
179template <class LocalOrdinal, class GlobalOrdinal, class Node>
184
185template <class LocalOrdinal, class GlobalOrdinal, class Node>
190
191template <class LocalOrdinal, class GlobalOrdinal, class Node>
193 XPETRA_MONITOR("TpetraCrsGraph::getDomainMap");
194 return toXpetra(graph_->getDomainMap());
195}
196
197template <class LocalOrdinal, class GlobalOrdinal, class Node>
199 XPETRA_MONITOR("TpetraCrsGraph::getRangeMap");
200 return toXpetra(graph_->getRangeMap());
201}
202
203template <class LocalOrdinal, class GlobalOrdinal, class Node>
208
209template <class LocalOrdinal, class GlobalOrdinal, class Node>
214
215template <class LocalOrdinal, class GlobalOrdinal, class Node>
217 XPETRA_MONITOR("TpetraCrsGraph::getGlobalNumRows");
218 return graph_->getGlobalNumRows();
219}
220
221template <class LocalOrdinal, class GlobalOrdinal, class Node>
223 XPETRA_MONITOR("TpetraCrsGraph::getGlobalNumCols");
224 return graph_->getGlobalNumCols();
225}
226
227template <class LocalOrdinal, class GlobalOrdinal, class Node>
229 XPETRA_MONITOR("TpetraCrsGraph::getLocalNumRows");
230 return graph_->getLocalNumRows();
231}
232
233template <class LocalOrdinal, class GlobalOrdinal, class Node>
235 XPETRA_MONITOR("TpetraCrsGraph::getLocalNumCols");
236 return graph_->getLocalNumCols();
237}
238
239template <class LocalOrdinal, class GlobalOrdinal, class Node>
241 XPETRA_MONITOR("TpetraCrsGraph::getIndexBase");
242 return graph_->getIndexBase();
243}
244
245template <class LocalOrdinal, class GlobalOrdinal, class Node>
247 XPETRA_MONITOR("TpetraCrsGraph::getGlobalNumEntries");
248 return graph_->getGlobalNumEntries();
249}
250
251template <class LocalOrdinal, class GlobalOrdinal, class Node>
253 XPETRA_MONITOR("TpetraCrsGraph::getLocalNumEntries");
254 return graph_->getLocalNumEntries();
255}
256
257template <class LocalOrdinal, class GlobalOrdinal, class Node>
259 XPETRA_MONITOR("TpetraCrsGraph::getNumEntriesInGlobalRow");
260 return graph_->getNumEntriesInGlobalRow(globalRow);
261}
262
263template <class LocalOrdinal, class GlobalOrdinal, class Node>
265 XPETRA_MONITOR("TpetraCrsGraph::getNumEntriesInLocalRow");
266 return graph_->getNumEntriesInLocalRow(localRow);
267}
268
269template <class LocalOrdinal, class GlobalOrdinal, class Node>
271 XPETRA_MONITOR("TpetraCrsGraph::getNumAllocatedEntriesInGlobalRow");
272 return graph_->getNumAllocatedEntriesInGlobalRow(globalRow);
273}
274
275template <class LocalOrdinal, class GlobalOrdinal, class Node>
277 XPETRA_MONITOR("TpetraCrsGraph::getNumAllocatedEntriesInLocalRow");
278 return graph_->getNumAllocatedEntriesInLocalRow(localRow);
279}
280
281template <class LocalOrdinal, class GlobalOrdinal, class Node>
283 XPETRA_MONITOR("TpetraCrsGraph::getGlobalMaxNumRowEntries");
284 return graph_->getGlobalMaxNumRowEntries();
285}
286
287template <class LocalOrdinal, class GlobalOrdinal, class Node>
289 XPETRA_MONITOR("TpetraCrsGraph::getLocalMaxNumRowEntries");
290 return graph_->getLocalMaxNumRowEntries();
291}
292
293template <class LocalOrdinal, class GlobalOrdinal, class Node>
295 XPETRA_MONITOR("TpetraCrsGraph::hasColMap");
296 return graph_->hasColMap();
297}
298
299template <class LocalOrdinal, class GlobalOrdinal, class Node>
301 XPETRA_MONITOR("TpetraCrsGraph::isLocallyIndexed");
302 return graph_->isLocallyIndexed();
303}
304
305template <class LocalOrdinal, class GlobalOrdinal, class Node>
307 XPETRA_MONITOR("TpetraCrsGraph::isGloballyIndexed");
308 return graph_->isGloballyIndexed();
309}
310
311template <class LocalOrdinal, class GlobalOrdinal, class Node>
313 XPETRA_MONITOR("TpetraCrsGraph::isFillComplete");
314 return graph_->isFillComplete();
315}
316
317template <class LocalOrdinal, class GlobalOrdinal, class Node>
319 XPETRA_MONITOR("TpetraCrsGraph::isStorageOptimized");
320 return graph_->isStorageOptimized();
321}
322
323template <class LocalOrdinal, class GlobalOrdinal, class Node>
325 XPETRA_MONITOR("TpetraCrsGraph::getGlobalRowView");
326 typename Tpetra::CrsGraph<LocalOrdinal, GlobalOrdinal, Node>::global_inds_host_view_type indices;
327 graph_->getGlobalRowView(GlobalRow, indices);
328 Indices = ArrayView<const GlobalOrdinal>(indices.data(), indices.extent(0));
329}
330
331template <class LocalOrdinal, class GlobalOrdinal, class Node>
333 XPETRA_MONITOR("TpetraCrsGraph::getLocalRowView");
334 typename Tpetra::CrsGraph<LocalOrdinal, GlobalOrdinal, Node>::local_inds_host_view_type indices;
335 graph_->getLocalRowView(LocalRow, indices);
336 Indices = ArrayView<const LocalOrdinal>(indices.data(), indices.extent(0));
337}
338
339template <class LocalOrdinal, class GlobalOrdinal, class Node>
340#if KOKKOS_VERSION >= 40799
342#else
347
348template <class LocalOrdinal, class GlobalOrdinal, class Node>
352
353template <class LocalOrdinal, class GlobalOrdinal, class Node>
354void TpetraCrsGraph<LocalOrdinal, GlobalOrdinal, Node>::getLocalDiagOffsets(const Kokkos::View<size_t *, typename Node::device_type, Kokkos::MemoryUnmanaged> &offsets) const {
355 getTpetra_CrsGraph()->getLocalDiagOffsets(offsets);
356}
357
358template <class LocalOrdinal, class GlobalOrdinal, class Node>
360 // mfh 07 May 2018: See GitHub Issue #2565.
361 graph_->computeGlobalConstants();
362}
363
364template <class LocalOrdinal, class GlobalOrdinal, class Node>
366 XPETRA_MONITOR("TpetraCrsGraph::description");
367 return graph_->description();
368}
369
370template <class LocalOrdinal, class GlobalOrdinal, class Node>
372 XPETRA_MONITOR("TpetraCrsGraph::describe");
373 graph_->describe(out, verbLevel);
374}
375
376template <class LocalOrdinal, class GlobalOrdinal, class Node>
378 XPETRA_MONITOR("TpetraCrsGraph::getNodeRowPtrs");
379 return Kokkos::Compat::persistingView(graph_->getLocalRowPtrsHost());
380}
381
382template <class LocalOrdinal, class GlobalOrdinal, class Node>
387
388template <class LocalOrdinal, class GlobalOrdinal, class Node>
390 const Import &importer, CombineMode CM) {
391 XPETRA_MONITOR("TpetraCrsGraph::doImport");
392
393 XPETRA_DYNAMIC_CAST(const TpetraCrsGraphClass, source, tSource, "Xpetra::TpetraCrsGraph::doImport only accept Xpetra::TpetraCrsGraph as input arguments."); // TODO: remove and use toTpetra()
394 RCP<const Tpetra::CrsGraph<LocalOrdinal, GlobalOrdinal, Node> > v = tSource.getTpetra_CrsGraph();
395 // graph_->doImport(toTpetraCrsGraph(source), *tImporter.getTpetra_Import(), toTpetra(CM));
396
397 graph_->doImport(*v, toTpetra(importer), toTpetra(CM));
398}
399
400template <class LocalOrdinal, class GlobalOrdinal, class Node>
402 const Import &importer, CombineMode CM) {
403 XPETRA_MONITOR("TpetraCrsGraph::doExport");
404
405 XPETRA_DYNAMIC_CAST(const TpetraCrsGraphClass, dest, tDest, "Xpetra::TpetraCrsGraph::doImport only accept Xpetra::TpetraCrsGraph as input arguments."); // TODO: remove and use toTpetra()
407 graph_->doExport(*v, toTpetra(importer), toTpetra(CM));
408}
409
410template <class LocalOrdinal, class GlobalOrdinal, class Node>
412 const Export &exporter, CombineMode CM) {
413 XPETRA_MONITOR("TpetraCrsGraph::doImport");
414
415 XPETRA_DYNAMIC_CAST(const TpetraCrsGraphClass, source, tSource, "Xpetra::TpetraCrsGraph::doImport only accept Xpetra::TpetraCrsGraph as input arguments."); // TODO: remove and use toTpetra()
416 RCP<const Tpetra::CrsGraph<LocalOrdinal, GlobalOrdinal, Node> > v = tSource.getTpetra_CrsGraph();
417
418 graph_->doImport(*v, toTpetra(exporter), toTpetra(CM));
419}
420
421template <class LocalOrdinal, class GlobalOrdinal, class Node>
423 const Export &exporter, CombineMode CM) {
424 XPETRA_MONITOR("TpetraCrsGraph::doExport");
425
426 XPETRA_DYNAMIC_CAST(const TpetraCrsGraphClass, dest, tDest, "Xpetra::TpetraCrsGraph::doImport only accept Xpetra::TpetraCrsGraph as input arguments."); // TODO: remove and use toTpetra()
428
429 graph_->doExport(*v, toTpetra(exporter), toTpetra(CM));
430}
431
432template <class LocalOrdinal, class GlobalOrdinal, class Node>
433TpetraCrsGraph<LocalOrdinal, GlobalOrdinal, Node>::TpetraCrsGraph(const Teuchos::RCP<Tpetra::CrsGraph<LocalOrdinal, GlobalOrdinal, Node> > &graph)
434 : graph_(graph) {}
435
436template <class LocalOrdinal, class GlobalOrdinal, class Node>
438
439#ifdef HAVE_XPETRA_EPETRA
440
441#if ((defined(EPETRA_HAVE_OMP) && (!defined(HAVE_TPETRA_INST_OPENMP) || !defined(HAVE_TPETRA_INST_INT_INT))) || \
442 (!defined(EPETRA_HAVE_OMP) && (!defined(HAVE_TPETRA_INST_SERIAL) || !defined(HAVE_TPETRA_INST_INT_INT))))
443
444// specialization of TpetraCrsGraph for GO=LO=int
445template <>
447 : public CrsGraph<int, int, EpetraNode> {
448 typedef int LocalOrdinal;
449 typedef int GlobalOrdinal;
451
452 // The following typedef is used by the XPETRA_DYNAMIC_CAST() macro.
455
456 public:
458
459
461 TpetraCrsGraph(const RCP<const map_type> &rowMap, size_t maxNumEntriesPerRow, const RCP<ParameterList> &params = null) {
463 }
464
469
474
479
501 const typename local_graph_type::row_map_type &rowPointers,
502 const typename local_graph_type::entries_type::non_const_type &columnIndices,
503 const Teuchos::RCP<Teuchos::ParameterList> &plist = Teuchos::null) {
506 "int",
507 typeid(EpetraNode).name());
508 }
509
537
563 const Teuchos::RCP<const map_type> &rowMap,
564 const Teuchos::RCP<const map_type> &colMap,
565 const Teuchos::RCP<const map_type> &domainMap = Teuchos::null,
566 const Teuchos::RCP<const map_type> &rangeMap = Teuchos::null,
567 const Teuchos::RCP<Teuchos::ParameterList> &params = Teuchos::null) {
570 "int",
571 typeid(EpetraNode).name());
572 }
573
575 virtual ~TpetraCrsGraph() {}
576
578
580
581
584
586 void insertLocalIndices(const LocalOrdinal localRow, const ArrayView<const LocalOrdinal> &indices) {}
587
590
592 void allocateAllIndices(size_t numNonZeros, ArrayRCP<size_t> &rowptr, ArrayRCP<LocalOrdinal> &colind) {}
593
595 void setAllIndices(const ArrayRCP<size_t> &rowptr, const ArrayRCP<LocalOrdinal> &colind) {}
596
599
601
603
604
606 void fillComplete(const RCP<const Map<LocalOrdinal, GlobalOrdinal, Node> > &domainMap, const RCP<const Map<LocalOrdinal, GlobalOrdinal, Node> > &rangeMap, const RCP<ParameterList> &params = null) {}
607
609 void fillComplete(const RCP<ParameterList> &params = null) {}
610
613 const Teuchos::RCP<const map_type> &rangeMap,
614 const Teuchos::RCP<const Import<LocalOrdinal, GlobalOrdinal, Node> > &importer = null,
615 const Teuchos::RCP<const Export<LocalOrdinal, GlobalOrdinal, Node> > &exporter = null,
616 const Teuchos::RCP<Teuchos::ParameterList> &params = null) {}
617
619
621
622
624 RCP<const Comm<int> > getComm() const { return Teuchos::null; }
625
628
631
634
637
640
643
645 global_size_t getGlobalNumRows() const { return 0; }
646
648 global_size_t getGlobalNumCols() const { return 0; }
649
651 size_t getLocalNumRows() const { return 0; }
652
654 size_t getLocalNumCols() const { return 0; }
655
657 GlobalOrdinal getIndexBase() const { return 0; }
658
660 global_size_t getGlobalNumEntries() const { return 0; }
661
663 size_t getLocalNumEntries() const { return 0; }
664
666 size_t getNumEntriesInGlobalRow(GlobalOrdinal globalRow) const { return 0; }
667
669 size_t getNumEntriesInLocalRow(LocalOrdinal localRow) const { return 0; }
670
672 size_t getNumAllocatedEntriesInGlobalRow(GlobalOrdinal globalRow) const { return 0; }
673
675 size_t getNumAllocatedEntriesInLocalRow(LocalOrdinal localRow) const { return 0; }
676
678 size_t getGlobalMaxNumRowEntries() const { return 0; }
679
681 size_t getLocalMaxNumRowEntries() const { return 0; }
682
684 bool hasColMap() const { return false; }
685
687 bool isLocallyIndexed() const { return false; }
688
690 bool isGloballyIndexed() const { return false; }
691
693 bool isFillComplete() const { return false; }
694
696 bool isStorageOptimized() const { return false; }
697
700
703
707 "Epetra does not support Kokkos::StaticCrsGraph!");
709 }
710
713
715
717
718
720 std::string description() const { return std::string(""); }
721
724
726
728
729
732
734
736 //{@
737
740
744
748
752
756
757 // @}
758
760
761
763 TpetraCrsGraph(const Teuchos::RCP<Tpetra::CrsGraph<LocalOrdinal, GlobalOrdinal, Node> > &graph) {
765 }
766
769
771}; // TpetraCrsGraph class (specialization for LO=GO=int and NO=EpetraNode)
772#endif
773
774#if ((defined(EPETRA_HAVE_OMP) && (!defined(HAVE_TPETRA_INST_OPENMP) || !defined(HAVE_TPETRA_INST_INT_LONG_LONG))) || \
775 (!defined(EPETRA_HAVE_OMP) && (!defined(HAVE_TPETRA_INST_SERIAL) || !defined(HAVE_TPETRA_INST_INT_LONG_LONG))))
776
777// specialization of TpetraCrsGraph for GO=long long and NO=EpetraNode
778template <>
779class TpetraCrsGraph<int, long long, EpetraNode>
780 : public CrsGraph<int, long long, EpetraNode> {
781 typedef int LocalOrdinal;
782 typedef long long GlobalOrdinal;
784
785 // The following typedef is used by the XPETRA_DYNAMIC_CAST() macro.
788
789 public:
791
792
794 TpetraCrsGraph(const RCP<const map_type> &rowMap, size_t maxNumEntriesPerRow, const RCP<ParameterList> &params = null) {
796 }
797
802
804 TpetraCrsGraph(const RCP<const Map<LocalOrdinal, GlobalOrdinal, Node> > &rowMap, const RCP<const Map<LocalOrdinal, GlobalOrdinal, Node> > &colMap, size_t maxNumEntriesPerRow, const RCP<ParameterList> &params = null) {
806 }
807
812
834 const typename local_graph_type::row_map_type &rowPointers,
835 const typename local_graph_type::entries_type::non_const_type &columnIndices,
836 const Teuchos::RCP<Teuchos::ParameterList> &plist = Teuchos::null) {
839 "int",
840 typeid(EpetraNode).name());
841 }
842
870
896 const Teuchos::RCP<const map_type> &rowMap,
897 const Teuchos::RCP<const map_type> &colMap,
898 const Teuchos::RCP<const map_type> &domainMap = Teuchos::null,
899 const Teuchos::RCP<const map_type> &rangeMap = Teuchos::null,
900 const Teuchos::RCP<Teuchos::ParameterList> &params = Teuchos::null) {
903 "int",
904 typeid(EpetraNode).name());
905 }
906
936
938 virtual ~TpetraCrsGraph() {}
939
941
943
944
947
949 void insertLocalIndices(const LocalOrdinal localRow, const ArrayView<const LocalOrdinal> &indices) {}
950
953
955 void allocateAllIndices(size_t numNonZeros, ArrayRCP<size_t> &rowptr, ArrayRCP<LocalOrdinal> &colind) {}
956
958 void setAllIndices(const ArrayRCP<size_t> &rowptr, const ArrayRCP<LocalOrdinal> &colind) {}
959
962
964
966
967
969 void fillComplete(const RCP<const Map<LocalOrdinal, GlobalOrdinal, Node> > &domainMap, const RCP<const Map<LocalOrdinal, GlobalOrdinal, Node> > &rangeMap, const RCP<ParameterList> &params = null) {}
970
972 void fillComplete(const RCP<ParameterList> &params = null) {}
973
976 const Teuchos::RCP<const map_type> &rangeMap,
977 const Teuchos::RCP<const Import<LocalOrdinal, GlobalOrdinal, Node> > &importer = null,
978 const Teuchos::RCP<const Export<LocalOrdinal, GlobalOrdinal, Node> > &exporter = null,
979 const Teuchos::RCP<Teuchos::ParameterList> &params = null) {}
980
982
984
985
987 RCP<const Comm<int> > getComm() const { return Teuchos::null; }
988
991
994
997
1000
1003
1006
1008 global_size_t getGlobalNumRows() const { return 0; }
1009
1011 global_size_t getGlobalNumCols() const { return 0; }
1012
1014 size_t getLocalNumRows() const { return 0; }
1015
1017 size_t getLocalNumCols() const { return 0; }
1018
1020 GlobalOrdinal getIndexBase() const { return 0; }
1021
1024
1026 size_t getLocalNumEntries() const { return 0; }
1027
1029 size_t getNumEntriesInGlobalRow(GlobalOrdinal globalRow) const { return 0; }
1030
1032 size_t getNumEntriesInLocalRow(LocalOrdinal localRow) const { return 0; }
1033
1035 size_t getNumAllocatedEntriesInGlobalRow(GlobalOrdinal globalRow) const { return 0; }
1036
1038 size_t getNumAllocatedEntriesInLocalRow(LocalOrdinal localRow) const { return 0; }
1039
1041 size_t getGlobalMaxNumRowEntries() const { return 0; }
1042
1044 size_t getLocalMaxNumRowEntries() const { return 0; }
1045
1047 bool hasColMap() const { return false; }
1048
1050 bool isLocallyIndexed() const { return false; }
1051
1053 bool isGloballyIndexed() const { return false; }
1054
1056 bool isFillComplete() const { return false; }
1057
1059 bool isStorageOptimized() const { return false; }
1060
1063
1066
1069 "Epetra does not support Kokkos::StaticCrsGraph!");
1071 }
1072
1073 void getLocalDiagOffsets(const Kokkos::View<size_t *, typename Node::device_type, Kokkos::MemoryUnmanaged> &offsets) const {
1075 "Epetra does not support getLocalDiagOffsets!");
1076 }
1077
1078#if KOKKOS_VERSION >= 40799
1079 typename local_graph_type::host_mirror_type getLocalGraphHost() const {
1081 "Epetra does not support Kokkos::StaticCrsGraph!");
1082 TEUCHOS_UNREACHABLE_RETURN((local_graph_type::host_mirror_type()));
1083 }
1084#else
1085 typename local_graph_type::HostMirror getLocalGraphHost() const {
1087 "Epetra does not support Kokkos::StaticCrsGraph!");
1088 TEUCHOS_UNREACHABLE_RETURN((local_graph_type::HostMirror()));
1089 }
1090#endif
1091
1094
1096
1098
1099
1101 std::string description() const { return std::string(""); }
1102
1105
1107
1109
1110
1113
1115
1117 //{@
1118
1121
1125
1129
1133
1137
1138 // @}
1139
1141
1142
1144 TpetraCrsGraph(const Teuchos::RCP<Tpetra::CrsGraph<LocalOrdinal, GlobalOrdinal, Node> > &graph) {
1146 }
1147
1150
1152}; // TpetraCrsGraph class (specialization for GO=long long and NO=EpetraNode)
1153#endif
1154
1155#endif // HAVE_XPETRA_EPETRA
1156
1157} // namespace Xpetra
1158#endif // XPETRA_TPETRACRSGRAPH_DEF_HPP
#define XPETRA_MONITOR(funcName)
#define XPETRA_DYNAMIC_CAST(type, obj, newObj, exceptionMsg)
#define XPETRA_TPETRA_ETI_EXCEPTION(cl, obj, go, node)
void resize(const size_type n, const T &val=T())
static const EVerbosityLevel verbLevel_default
bool is_null() const
T * get() const
virtual local_graph_type::HostMirror getLocalGraphHost() const =0
Get the local graph.
KokkosSparse::StaticCrsGraph< LocalOrdinal, Kokkos::LayoutLeft, device_type, void, size_t > local_graph_type
Exception throws to report errors in the internal logical of the program.
Teuchos::RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > getMap() const
Implements DistObject interface.
bool isStorageOptimized() const
Returns true if storage has been optimized.
TpetraCrsGraph(const RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > &rowMap, const RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > &colMap, size_t maxNumEntriesPerRow, const RCP< ParameterList > &params=null)
Constructor specifying column Map and fixed number of entries for each row.
void computeGlobalConstants()
Dummy implementation for computeGlobalConstants.
TpetraCrsGraph(const local_graph_type &lclGraph, const Teuchos::RCP< const map_type > &rowMap, const Teuchos::RCP< const map_type > &colMap, const Teuchos::RCP< const map_type > &domainMap=Teuchos::null, const Teuchos::RCP< const map_type > &rangeMap=Teuchos::null, const Teuchos::RCP< Teuchos::ParameterList > &params=Teuchos::null)
Constructor specifying column, domain and range maps, and a local (sorted) graph, which the resulting...
void removeLocalIndices(LocalOrdinal localRow)
Remove all graph indices from the specified local row.
size_t getNumAllocatedEntriesInGlobalRow(GlobalOrdinal globalRow) const
Returns the current number of allocated entries for this node in the specified global row .
TpetraCrsGraph< LocalOrdinal, GlobalOrdinal, Node > TpetraCrsGraphClass
size_t getLocalNumCols() const
Returns the number of columns connected to the locally owned rows of this graph.
bool isGloballyIndexed() const
Whether column indices are stored using global indices on the calling process.
Map< LocalOrdinal, GlobalOrdinal, Node > map_type
void setAllIndices(const ArrayRCP< size_t > &rowptr, const ArrayRCP< LocalOrdinal > &colind)
Sets the 1D pointer arrays of the graph.
bool isLocallyIndexed() const
Whether column indices are stored using local indices on the calling process.
global_size_t getGlobalNumRows() const
Returns the number of global rows in the graph.
TpetraCrsGraph(const RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > &rowMap, const RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > &colMap, const ArrayRCP< const size_t > &NumEntriesPerRowToAlloc, const RCP< ParameterList > &params=null)
Constructor specifying column Map and number of entries in each row.
void doImport(const DistObject< GlobalOrdinal, LocalOrdinal, GlobalOrdinal, Node > &source, const Import< LocalOrdinal, GlobalOrdinal, Node > &importer, CombineMode CM)
Import.
void allocateAllIndices(size_t numNonZeros, ArrayRCP< size_t > &rowptr, ArrayRCP< LocalOrdinal > &colind)
Allocates the 1D pointer arrays of the graph.
TpetraCrsGraph(const Teuchos::RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > &rowMap, const Teuchos::RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > &colMap, const typename local_graph_type::row_map_type &rowPointers, const typename local_graph_type::entries_type::non_const_type &columnIndices, const Teuchos::RCP< Teuchos::ParameterList > &plist=Teuchos::null)
Constructor specifying column Map and arrays containing the graph in sorted, local ids.
void describe(Teuchos::FancyOStream &out, const Teuchos::EVerbosityLevel verbLevel=Teuchos::Describable::verbLevel_default) const
Print the object with some verbosity level to an FancyOStream object.
size_t getLocalNumEntries() const
Returns the local number of entries in the graph.
TpetraCrsGraph(const RCP< const map_type > &rowMap, size_t maxNumEntriesPerRow, const RCP< ParameterList > &params=null)
Constructor specifying fixed number of entries for each row.
GlobalOrdinal getIndexBase() const
Returns the index base for global indices for this graph.
void insertLocalIndices(const LocalOrdinal localRow, const ArrayView< const LocalOrdinal > &indices)
Insert local indices into the graph.
TpetraCrsGraph(const RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > &rowMap, const ArrayRCP< const size_t > &NumEntriesPerRowToAlloc, const RCP< ParameterList > &params=null)
Constructor specifying (possibly different) number of entries in each row.
RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > getDomainMap() const
Returns the Map associated with the domain of this graph.
global_size_t getGlobalNumCols() const
Returns the number of global columns in the graph.
void fillComplete(const RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > &domainMap, const RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > &rangeMap, const RCP< ParameterList > &params=null)
Signal that data entry is complete, specifying domain and range maps.
void fillComplete(const RCP< ParameterList > &params=null)
Signal that data entry is complete.
RCP< const Import< LocalOrdinal, GlobalOrdinal, Node > > getImporter() const
Returns the importer associated with this graph.
void doExport(const DistObject< GlobalOrdinal, LocalOrdinal, GlobalOrdinal, Node > &dest, const Import< LocalOrdinal, GlobalOrdinal, Node > &importer, CombineMode CM)
Export.
void getAllIndices(ArrayRCP< const size_t > &rowptr, ArrayRCP< const LocalOrdinal > &colind) const
Gets the 1D pointer arrays of the graph.
void insertGlobalIndices(GlobalOrdinal globalRow, const ArrayView< const GlobalOrdinal > &indices)
Insert global indices into the graph.
RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > getRangeMap() const
Returns the Map associated with the domain of this graph.
void doImport(const DistObject< GlobalOrdinal, LocalOrdinal, GlobalOrdinal, Node > &source, const Export< LocalOrdinal, GlobalOrdinal, Node > &exporter, CombineMode CM)
Import (using an Exporter).
local_graph_type getLocalGraph() const
Access the local KokkosSparse::StaticCrsGraph data.
ArrayRCP< const size_t > getNodeRowPtrs() const
Get an ArrayRCP of the row-offsets.
void getGlobalRowView(GlobalOrdinal GlobalRow, ArrayView< const GlobalOrdinal > &Indices) const
Return a const, nonpersisting view of global indices in the given row.
TpetraCrsGraph(const Teuchos::RCP< Tpetra::CrsGraph< LocalOrdinal, GlobalOrdinal, Node > > &graph)
TpetraCrsGraph constructor to wrap a Tpetra::CrsGraph object.
RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > getColMap() const
Returns the Map that describes the column distribution in this graph.
void doExport(const DistObject< GlobalOrdinal, LocalOrdinal, GlobalOrdinal, Node > &dest, const Export< LocalOrdinal, GlobalOrdinal, Node > &exporter, CombineMode CM)
Export (using an Importer).
std::string description() const
Return a simple one-line description of this object.
size_t getGlobalMaxNumRowEntries() const
Maximum number of entries in all rows over all processes.
size_t getLocalNumRows() const
Returns the number of graph rows owned on the calling node.
size_t getLocalMaxNumRowEntries() const
Maximum number of entries in all rows owned by the calling process.
RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > getRowMap() const
Returns the Map that describes the row distribution in this graph.
void expertStaticFillComplete(const Teuchos::RCP< const map_type > &domainMap, const Teuchos::RCP< const map_type > &rangeMap, const Teuchos::RCP< const Import< LocalOrdinal, GlobalOrdinal, Node > > &importer=null, const Teuchos::RCP< const Export< LocalOrdinal, GlobalOrdinal, Node > > &exporter=null, const Teuchos::RCP< Teuchos::ParameterList > &params=null)
Expert version of fillComplete.
bool hasColMap() const
Whether the graph has a column Map.
TpetraCrsGraph(const Teuchos::RCP< const map_type > &rowMap, const Teuchos::RCP< const map_type > &colMap, const local_graph_type &lclGraph, const Teuchos::RCP< Teuchos::ParameterList > &params)
Constructor specifying column Map and a local (sorted) graph, which the resulting CrsGraph views.
bool isFillComplete() const
Whether fillComplete() has been called and the graph is in compute mode.
RCP< const Tpetra::CrsGraph< LocalOrdinal, GlobalOrdinal, Node > > getTpetra_CrsGraph() const
Get the underlying Tpetra graph.
global_size_t getGlobalNumEntries() const
Returns the global number of entries in the graph.
RCP< const Comm< int > > getComm() const
Returns the communicator.
size_t getNumEntriesInGlobalRow(GlobalOrdinal globalRow) const
Returns the current number of entries on this node in the specified global row.
void getLocalRowView(LocalOrdinal LocalRow, ArrayView< const LocalOrdinal > &indices) const
Return a const, nonpersisting view of local indices in the given row.
size_t getNumAllocatedEntriesInLocalRow(LocalOrdinal localRow) const
Returns the current number of allocated entries on this node in the specified local row.
size_t getNumEntriesInLocalRow(LocalOrdinal localRow) const
Returns the current number of entries on this node in the specified local row.
RCP< const Export< LocalOrdinal, GlobalOrdinal, Node > > getExporter() const
Returns the exporter associated with this graph.
void insertLocalIndices(const LocalOrdinal localRow, const ArrayView< const LocalOrdinal > &indices)
Insert local indices into the graph.
void setAllIndices(const ArrayRCP< size_t > &rowptr, const ArrayRCP< LocalOrdinal > &colind)
Sets the 1D pointer arrays of the graph.
RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > getColMap() const
Returns the Map that describes the column distribution in this graph.
RCP< const Import< LocalOrdinal, GlobalOrdinal, Node > > getImporter() const
Returns the importer associated with this graph.
global_size_t getGlobalNumEntries() const
Returns the global number of entries in the graph.
void fillComplete(const RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > &domainMap, const RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > &rangeMap, const RCP< ParameterList > &params=null)
Signal that data entry is complete, specifying domain and range maps.
size_t getLocalMaxNumRowEntries() const
Maximum number of entries in all rows owned by the calling process.
void expertStaticFillComplete(const Teuchos::RCP< const map_type > &domainMap, const Teuchos::RCP< const map_type > &rangeMap, const Teuchos::RCP< const Import< LocalOrdinal, GlobalOrdinal, Node > > &importer=null, const Teuchos::RCP< const Export< LocalOrdinal, GlobalOrdinal, Node > > &exporter=null, const Teuchos::RCP< Teuchos::ParameterList > &params=null)
Expert version of fillComplete.
void doExport(const DistObject< GlobalOrdinal, LocalOrdinal, GlobalOrdinal, Node > &dest, const Export< LocalOrdinal, GlobalOrdinal, Node > &exporter, CombineMode CM)
Export (using an Importer).
bool hasColMap() const
Whether the graph has a column Map.
void fillComplete(const RCP< ParameterList > &params=null)
Signal that data entry is complete.
void describe(Teuchos::FancyOStream &out, const Teuchos::EVerbosityLevel verbLevel=Teuchos::Describable::verbLevel_default) const
Print the object with some verbosity level to an FancyOStream object.
void getAllIndices(ArrayRCP< const size_t > &rowptr, ArrayRCP< const LocalOrdinal > &colind) const
Gets the 1D pointer arrays of the graph.
size_t getNumEntriesInLocalRow(LocalOrdinal localRow) const
Returns the current number of entries on this node in the specified local row.
bool isLocallyIndexed() const
Whether column indices are stored using local indices on the calling process.
TpetraCrsGraph(const RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > &rowMap, const RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > &colMap, const ArrayRCP< const size_t > &NumEntriesPerRowToAlloc, const RCP< ParameterList > &params=null)
Constructor specifying column Map and number of entries in each row.
RCP< const Tpetra::CrsGraph< LocalOrdinal, GlobalOrdinal, Node > > getTpetra_CrsGraph() const
Get the underlying Tpetra graph.
size_t getNumAllocatedEntriesInLocalRow(LocalOrdinal localRow) const
Returns the current number of allocated entries on this node in the specified local row.
local_graph_type::HostMirror getLocalGraphHost() const
Get the local graph.
Teuchos::RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > getMap() const
Implements DistObject interface.
void getLocalRowView(LocalOrdinal LocalRow, ArrayView< const LocalOrdinal > &indices) const
Return a const, nonpersisting view of local indices in the given row.
void getLocalDiagOffsets(const Kokkos::View< size_t *, typename Node::device_type, Kokkos::MemoryUnmanaged > &offsets) const
void doExport(const DistObject< GlobalOrdinal, LocalOrdinal, GlobalOrdinal, Node > &dest, const Import< LocalOrdinal, GlobalOrdinal, Node > &importer, CombineMode CM)
Export.
size_t getNumEntriesInGlobalRow(GlobalOrdinal globalRow) const
Returns the current number of entries on this node in the specified global row.
TpetraCrsGraph(const RCP< const map_type > &rowMap, size_t maxNumEntriesPerRow, const RCP< ParameterList > &params=null)
Constructor specifying fixed number of entries for each row.
void allocateAllIndices(size_t numNonZeros, ArrayRCP< size_t > &rowptr, ArrayRCP< LocalOrdinal > &colind)
Allocates the 1D pointer arrays of the graph.
TpetraCrsGraph(const local_graph_type &lclGraph, const Teuchos::RCP< const map_type > &rowMap, const Teuchos::RCP< const map_type > &colMap, const Teuchos::RCP< const map_type > &domainMap=Teuchos::null, const Teuchos::RCP< const map_type > &rangeMap=Teuchos::null, const Teuchos::RCP< Teuchos::ParameterList > &params=Teuchos::null)
Constructor specifying column, domain and range maps, and a local (sorted) graph, which the resulting...
TpetraCrsGraph(const RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > &rowMap, const RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > &colMap, size_t maxNumEntriesPerRow, const RCP< ParameterList > &params=null)
Constructor specifying column Map and fixed number of entries for each row.
void getGlobalRowView(GlobalOrdinal GlobalRow, ArrayView< const GlobalOrdinal > &Indices) const
Return a const, nonpersisting view of global indices in the given row.
TpetraCrsGraph(const Teuchos::RCP< const map_type > &rowMap, const Teuchos::RCP< const map_type > &colMap, const Teuchos::ArrayRCP< size_t > &rowPointers, const Teuchos::ArrayRCP< LocalOrdinal > &columnIndices, const Teuchos::RCP< Teuchos::ParameterList > &params)
Constructor specifying column Map and arrays containing the graph in sorted, local ids.
global_size_t getGlobalNumRows() const
Returns the number of global rows in the graph.
global_size_t getGlobalNumCols() const
Returns the number of global columns in the graph.
size_t getLocalNumRows() const
Returns the number of graph rows owned on the calling node.
void insertGlobalIndices(GlobalOrdinal globalRow, const ArrayView< const GlobalOrdinal > &indices)
Insert global indices into the graph.
size_t getNumAllocatedEntriesInGlobalRow(GlobalOrdinal globalRow) const
Returns the current number of allocated entries for this node in the specified global row .
bool isGloballyIndexed() const
Whether column indices are stored using global indices on the calling process.
void doImport(const DistObject< GlobalOrdinal, LocalOrdinal, GlobalOrdinal, Node > &source, const Export< LocalOrdinal, GlobalOrdinal, Node > &exporter, CombineMode CM)
Import (using an Exporter).
TpetraCrsGraph(const Teuchos::RCP< Tpetra::CrsGraph< LocalOrdinal, GlobalOrdinal, Node > > &graph)
TpetraCrsGraph constructor to wrap a Tpetra::CrsGraph object.
size_t getLocalNumEntries() const
Returns the local number of entries in the graph.
size_t getLocalNumCols() const
Returns the number of columns connected to the locally owned rows of this graph.
RCP< const Comm< int > > getComm() const
Returns the communicator.
void removeLocalIndices(LocalOrdinal localRow)
Remove all graph indices from the specified local row.
GlobalOrdinal getIndexBase() const
Returns the index base for global indices for this graph.
RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > getDomainMap() const
Returns the Map associated with the domain of this graph.
void doImport(const DistObject< GlobalOrdinal, LocalOrdinal, GlobalOrdinal, Node > &source, const Import< LocalOrdinal, GlobalOrdinal, Node > &importer, CombineMode CM)
Import.
std::string description() const
Return a simple one-line description of this object.
RCP< const Export< LocalOrdinal, GlobalOrdinal, Node > > getExporter() const
Returns the exporter associated with this graph.
RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > getRowMap() const
Returns the Map that describes the row distribution in this graph.
TpetraCrsGraph(const Teuchos::RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > &rowMap, const Teuchos::RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > &colMap, const typename local_graph_type::row_map_type &rowPointers, const typename local_graph_type::entries_type::non_const_type &columnIndices, const Teuchos::RCP< Teuchos::ParameterList > &plist=Teuchos::null)
Constructor specifying column Map and arrays containing the graph in sorted, local ids.
size_t getGlobalMaxNumRowEntries() const
Maximum number of entries in all rows over all processes.
TpetraCrsGraph(const RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > &rowMap, const ArrayRCP< const size_t > &NumEntriesPerRowToAlloc, const RCP< ParameterList > &params=null)
Constructor specifying (possibly different) number of entries in each row.
TpetraCrsGraph(const Teuchos::RCP< const map_type > &rowMap, const Teuchos::RCP< const map_type > &colMap, const local_graph_type &lclGraph, const Teuchos::RCP< Teuchos::ParameterList > &params)
Constructor specifying column Map and a local (sorted) graph, which the resulting CrsGraph views.
ArrayRCP< const size_t > getNodeRowPtrs() const
Get an ArrayRCP of the row-offsets.
void computeGlobalConstants()
Dummy implementation for computeGlobalConstants.
bool isStorageOptimized() const
Returns true if storage has been optimized.
TpetraCrsGraph< LocalOrdinal, GlobalOrdinal, Node > TpetraCrsGraphClass
bool isFillComplete() const
Whether fillComplete() has been called and the graph is in compute mode.
RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > getRangeMap() const
Returns the Map associated with the domain of this graph.
void setAllIndices(const ArrayRCP< size_t > &rowptr, const ArrayRCP< LocalOrdinal > &colind)
Sets the 1D pointer arrays of the graph.
void fillComplete(const RCP< const Map > &domainMap, const RCP< const Map > &rangeMap, const RCP< ParameterList > &params=null)
Signal that data entry is complete, specifying domain and range maps.
RCP< const Comm< int > > getComm() const
Returns the communicator.
size_t getLocalMaxNumRowEntries() const
Maximum number of entries in all rows owned by the calling process.
RCP< const Tpetra::CrsGraph< LocalOrdinal, GlobalOrdinal, Node > > getTpetra_CrsGraph() const
Get the underlying Tpetra graph.
void insertLocalIndices(const LocalOrdinal localRow, const ArrayView< const LocalOrdinal > &indices)
Insert local indices into the graph.
void allocateAllIndices(size_t numNonZeros, ArrayRCP< size_t > &rowptr, ArrayRCP< LocalOrdinal > &colind)
Allocates the 1D pointer arrays of the graph.
void insertGlobalIndices(GlobalOrdinal globalRow, const ArrayView< const GlobalOrdinal > &indices)
Insert global indices into the graph.
global_size_t getGlobalNumCols() const
Returns the number of global columns in the graph.
void expertStaticFillComplete(const Teuchos::RCP< const map_type > &domainMap, const Teuchos::RCP< const map_type > &rangeMap, const Teuchos::RCP< const Import > &importer=Teuchos::null, const Teuchos::RCP< const Export > &exporter=Teuchos::null, const Teuchos::RCP< Teuchos::ParameterList > &params=Teuchos::null)
Expert version of fillComplete.
TpetraCrsGraph(const RCP< const Map > &rowMap, size_t maxNumEntriesPerRow, const RCP< ParameterList > &params=null)
Constructor specifying fixed number of entries for each row.
size_t getNumEntriesInGlobalRow(GlobalOrdinal globalRow) const
Returns the current number of entries on this node in the specified global row.
RCP< const Import > getImporter() const
Returns the importer associated with this graph.
void removeLocalIndices(LocalOrdinal localRow)
Remove all graph indices from the specified local row.
bool isLocallyIndexed() const
Whether column indices are stored using local indices on the calling process.
size_t getNumAllocatedEntriesInLocalRow(LocalOrdinal localRow) const
Returns the current number of allocated entries on this node in the specified local row.
size_t getGlobalMaxNumRowEntries() const
Maximum number of entries in all rows over all processes.
size_t getLocalNumCols() const
Returns the number of columns connected to the locally owned rows of this graph.
size_t getNumEntriesInLocalRow(LocalOrdinal localRow) const
Returns the current number of entries on this node in the specified local row.
bool isFillComplete() const
Whether fillComplete() has been called and the graph is in compute mode.
local_graph_type getLocalGraphDevice() const
Access the local KokkosSparse::StaticCrsGraph data for device use.
size_t getNumAllocatedEntriesInGlobalRow(GlobalOrdinal globalRow) const
Returns the current number of allocated entries for this node in the specified global row .
size_t getLocalNumRows() const
Returns the number of graph rows owned on the calling node.
void computeGlobalConstants()
Force the computation of global constants if we don't have them.
bool hasColMap() const
Whether the graph has a column Map.
void doExport(const DistObject< GlobalOrdinal, LocalOrdinal, GlobalOrdinal, Node > &dest, const Import &importer, CombineMode CM)
Export.
void getGlobalRowView(GlobalOrdinal GlobalRow, ArrayView< const GlobalOrdinal > &Indices) const
Return a const, nonpersisting view of global indices in the given row.
RCP< const Map > getRowMap() const
Returns the Map that describes the row distribution in this graph.
RCP< const Map > getRangeMap() const
Returns the Map associated with the domain of this graph.
size_t getLocalNumEntries() const
Returns the local number of entries in the graph.
bool isStorageOptimized() const
Returns true if storage has been optimized.
void getAllIndices(ArrayRCP< const size_t > &rowptr, ArrayRCP< const LocalOrdinal > &colind) const
Gets the 1D pointer arrays of the graph.
void getLocalDiagOffsets(const Kokkos::View< size_t *, typename Node::device_type, Kokkos::MemoryUnmanaged > &offsets) const
Get offsets of the diagonal entries in the matrix.
local_graph_type::HostMirror getLocalGraphHost() const
Access the local KokkosSparse::StaticCrsGraph data for host use.
void describe(Teuchos::FancyOStream &out, const Teuchos::EVerbosityLevel verbLevel=Teuchos::Describable::verbLevel_default) const
Print the object with some verbosity level to an FancyOStream object.
void doImport(const DistObject< GlobalOrdinal, LocalOrdinal, GlobalOrdinal, Node > &source, const Import &importer, CombineMode CM)
Import.
Xpetra::CrsGraph< LocalOrdinal, GlobalOrdinal, Node >::local_graph_type local_graph_type
Teuchos::RCP< const Map > getMap() const
Implements DistObject interface.
bool isGloballyIndexed() const
Whether column indices are stored using global indices on the calling process.
std::string description() const
Return a simple one-line description of this object.
GlobalOrdinal getIndexBase() const
Returns the index base for global indices for this graph.
RCP< const Export > getExporter() const
Returns the exporter associated with this graph.
ArrayRCP< const size_t > getNodeRowPtrs() const
Get an ArrayRCP of the row-offsets.
RCP< const Map > getDomainMap() const
Returns the Map associated with the domain of this graph.
void getLocalRowView(LocalOrdinal LocalRow, ArrayView< const LocalOrdinal > &indices) const
Return a const, nonpersisting view of local indices in the given row.
global_size_t getGlobalNumEntries() const
Returns the global number of entries in the graph.
global_size_t getGlobalNumRows() const
Returns the number of global rows in the graph.
RCP< const Map > getColMap() const
Returns the Map that describes the column distribution in this graph.
#define TEUCHOS_TEST_FOR_EXCEPTION(throw_exception_test, Exception, msg)
#define TEUCHOS_UNREACHABLE_RETURN(dummyReturnVal)
TEUCHOS_DEPRECATED RCP< T > rcp(T *p, Dealloc_T dealloc, bool owns_mem)
Tpetra::KokkosCompat::KokkosSerialWrapperNode EpetraNode
size_t global_size_t
Global size_t object.
RCP< const CrsGraph< int, GlobalOrdinal, Node > > toXpetra(const Epetra_CrsGraph &g)
RCP< const Tpetra::CrsGraph< LocalOrdinal, GlobalOrdinal, Node > > toTpetra(const RCP< const CrsGraph< LocalOrdinal, GlobalOrdinal, Node > > &graph)
CombineMode
Xpetra::Combine Mode enumerable type.