10#ifndef TPETRA_CRSGRAPH_DECL_HPP
11#define TPETRA_CRSGRAPH_DECL_HPP
19#include "Tpetra_DistObject.hpp"
20#include "Tpetra_Exceptions.hpp"
21#include "Tpetra_RowGraph.hpp"
23#include "Tpetra_Details_WrappedDualView.hpp"
24#include "Tpetra_Details_makeColMap.hpp"
26#include "KokkosSparse_findRelOffset.hpp"
27#include "Kokkos_DualView.hpp"
29#include "Teuchos_CommHelpers.hpp"
30#include "Teuchos_Describable.hpp"
31#include "Teuchos_OrdinalTraits.hpp"
32#include "Teuchos_ParameterListAcceptorDefaultBase.hpp"
34#include "KokkosSparse_StaticCrsGraph.hpp"
42template <
class LocalOrdinal,
class GlobalOrdinal,
class Node>
43class crsGraph_Swap_Tester;
45#ifndef DOXYGEN_SHOULD_SKIP_THIS
47template <
class LocalOrdinal,
54template <
class ViewType>
56 static_assert(Kokkos::is_view<ViewType>::value,
57 "ViewType must be a Kokkos::View specialization.");
61 typedef Kokkos::View<
typename ViewType::data_type,
62 typename ViewType::array_layout,
63 typename ViewType::device_type,
64 Kokkos::MemoryUnmanaged>
188template <
class LocalOrdinal,
196 public Teuchos::ParameterListAcceptorDefaultBase {
197 template <
class S,
class LO,
class GO,
class N>
199 template <
class LO2,
class GO2,
class N2>
201 template <
class LO,
class GO,
class N>
240 using local_inds_dualv_type =
241 Kokkos::DualView<local_ordinal_type*, device_type>;
246 using global_inds_dualv_type =
247 Kokkos::DualView<global_ordinal_type*, device_type>;
253 using row_ptrs_device_view_type =
254 typename row_graph_type::row_ptrs_device_view_type;
255 using row_ptrs_host_view_type =
256 typename row_graph_type::row_ptrs_host_view_type;
260 typename row_graph_type::local_inds_device_view_type;
261 using local_inds_host_view_type =
262 typename row_graph_type::local_inds_host_view_type;
263 using nonconst_local_inds_host_view_type =
264 typename row_graph_type::nonconst_local_inds_host_view_type;
268 typename row_graph_type::global_inds_device_view_type;
269 using global_inds_host_view_type =
270 typename row_graph_type::global_inds_host_view_type;
271 using nonconst_global_inds_host_view_type =
272 typename row_graph_type::nonconst_global_inds_host_view_type;
274 using offset_device_view_type =
275 typename row_ptrs_device_view_type::non_const_type;
292 CrsGraph(
const Teuchos::RCP<const map_type>& rowMap,
294 const Teuchos::RCP<Teuchos::ParameterList>&
params = Teuchos::null);
308 CrsGraph(
const Teuchos::RCP<const map_type>& rowMap,
309 const Kokkos::DualView<const size_t*, device_type>&
numEntPerRow,
310 const Teuchos::RCP<Teuchos::ParameterList>&
params = Teuchos::null);
325 CrsGraph(
const Teuchos::RCP<const map_type>& rowMap,
327 const Teuchos::RCP<Teuchos::ParameterList>&
params = Teuchos::null);
345 CrsGraph(
const Teuchos::RCP<const map_type>& rowMap,
346 const Teuchos::RCP<const map_type>& colMap,
348 const Teuchos::RCP<Teuchos::ParameterList>&
params = Teuchos::null);
364 CrsGraph(
const Teuchos::RCP<const map_type>& rowMap,
365 const Teuchos::RCP<const map_type>& colMap,
366 const Kokkos::DualView<const size_t*, device_type>&
numEntPerRow,
367 const Teuchos::RCP<Teuchos::ParameterList>&
params = Teuchos::null);
384 CrsGraph(
const Teuchos::RCP<const map_type>& rowMap,
385 const Teuchos::RCP<const map_type>& colMap,
387 const Teuchos::RCP<Teuchos::ParameterList>&
params = Teuchos::null);
402 const Teuchos::RCP<const map_type>& rowMap,
403 const Teuchos::RCP<Teuchos::ParameterList>&
params = Teuchos::null);
427 CrsGraph(
const Teuchos::RCP<const map_type>& rowMap,
428 const Teuchos::RCP<const map_type>& colMap,
429 const typename local_graph_device_type::row_map_type&
rowPointers,
430 const typename local_graph_device_type::entries_type::non_const_type&
columnIndices,
431 const Teuchos::RCP<Teuchos::ParameterList>&
params = Teuchos::null);
455 CrsGraph(
const Teuchos::RCP<const map_type>& rowMap,
456 const Teuchos::RCP<const map_type>& colMap,
459 const Teuchos::RCP<Teuchos::ParameterList>&
params = Teuchos::null);
482 CrsGraph(
const Teuchos::RCP<const map_type>& rowMap,
483 const Teuchos::RCP<const map_type>& colMap,
485 const Teuchos::RCP<Teuchos::ParameterList>&
params = Teuchos::null);
514 const Teuchos::RCP<const map_type>& rowMap,
515 const Teuchos::RCP<const map_type>& colMap,
516 const Teuchos::RCP<const map_type>& domainMap = Teuchos::null,
517 const Teuchos::RCP<const map_type>&
rangeMap = Teuchos::null,
518 const Teuchos::RCP<Teuchos::ParameterList>&
params = Teuchos::null);
525 const Teuchos::RCP<const map_type>& rowMap,
526 const Teuchos::RCP<const map_type>& colMap,
527 const Teuchos::RCP<const map_type>& domainMap,
528 const Teuchos::RCP<const map_type>&
rangeMap,
529 const Teuchos::RCP<const import_type>&
importer,
530 const Teuchos::RCP<const export_type>&
exporter,
531 const Teuchos::RCP<Teuchos::ParameterList>&
params =
577 const Teuchos::RCP<const map_type>& rowMap,
578 const Teuchos::RCP<const map_type>& colMap,
579 const Teuchos::RCP<const map_type>& domainMap,
580 const Teuchos::RCP<const map_type>&
rangeMap,
581 const Teuchos::RCP<const import_type>&
importer,
582 const Teuchos::RCP<const export_type>&
exporter,
583 const Teuchos::RCP<Teuchos::ParameterList>&
params =
664 Teuchos::RCP<const Teuchos::ParameterList>
694 const Teuchos::ArrayView<const global_ordinal_type>& indices);
724 const Teuchos::ArrayView<const local_ordinal_type>& indices);
822 fillComplete(
const Teuchos::RCP<const map_type>& domainMap,
823 const Teuchos::RCP<const map_type>&
rangeMap,
824 const Teuchos::RCP<Teuchos::ParameterList>&
params = Teuchos::null);
886 const Teuchos::RCP<const map_type>&
rangeMap,
887 const Teuchos::RCP<const import_type>&
importer =
889 const Teuchos::RCP<const export_type>&
exporter =
891 const Teuchos::RCP<Teuchos::ParameterList>&
params =
898 Teuchos::RCP<const Teuchos::Comm<int>>
getComm()
const override;
901 Teuchos::RCP<const map_type>
getRowMap()
const override;
904 Teuchos::RCP<const map_type>
getColMap()
const override;
907 Teuchos::RCP<const map_type>
getDomainMap()
const override;
910 Teuchos::RCP<const map_type>
getRangeMap()
const override;
913 Teuchos::RCP<const import_type>
getImporter()
const override;
916 Teuchos::RCP<const export_type>
getExporter()
const override;
1096 nonconst_global_inds_host_view_type&
gblColInds,
1108 nonconst_local_inds_host_view_type&
lclColInds,
1124 global_inds_host_view_type&
gblColInds)
const override;
1143 local_inds_host_view_type&
lclColInds)
const override;
1156 const Teuchos::EVerbosityLevel
verbLevel =
1157 Teuchos::Describable::verbLevel_default)
const override;
1180 const size_t numSameIDs,
1187 void copyAndPermuteNew(
1190 const size_t numSameIDs,
1191 const Kokkos::DualView<const local_ordinal_type*, buffer_device_type>&
permuteToLIDs,
1192 const Kokkos::DualView<const local_ordinal_type*, buffer_device_type>&
permuteFromLIDs,
1195 void insertGlobalIndicesDevice(
1198 const Kokkos::DualView<const local_ordinal_type*, buffer_device_type>&
permuteToLIDs,
1199 const Kokkos::DualView<const local_ordinal_type*, buffer_device_type>&
permuteFromLIDs,
1207 const bool verbose);
1209 std::unique_ptr<padding_type>
1213 const size_t numSameIDs,
1218 const bool verbose)
const;
1221 std::unique_ptr<padding_type>
1222 computeCrsPaddingForImports(
1225 Kokkos::DualView<packet_type*, buffer_device_type> imports,
1227 const bool verbose)
const;
1229 std::unique_ptr<padding_type>
1230 computePaddingForCrsMatrixUnpack(
1233 Kokkos::DualView<char*, buffer_device_type> imports,
1235 const bool verbose)
const;
1238 computeCrsPaddingForSameIDs(
1245 computeCrsPaddingForPermutedIDs(
1257 const Kokkos::DualView<const local_ordinal_type*, buffer_device_type>&
exportLIDs,
1258 Kokkos::DualView<packet_type*, buffer_device_type>& exports,
1268 pack(
const Teuchos::ArrayView<const local_ordinal_type>&
exportLIDs,
1269 Teuchos::Array<global_ordinal_type>& exports,
1274 packFillActive(
const Teuchos::ArrayView<const local_ordinal_type>&
exportLIDs,
1275 Teuchos::Array<global_ordinal_type>& exports,
1284 Kokkos::DualView<
size_t*,
1300 Kokkos::DualView<
size_t*,
1353 getLocalDiagOffsets(
const Kokkos::View<size_t*, device_type, Kokkos::MemoryUnmanaged>& offsets)
const;
1382 const typename local_graph_device_type::entries_type::non_const_type&
columnIndices);
1395 const Teuchos::ArrayRCP<local_ordinal_type>&
columnIndices);
1452 const Teuchos::RCP<const import_type>&
newImport = Teuchos::null,
1479 const Teuchos::RCP<const import_type>&
newImporter);
1505 const Teuchos::RCP<const export_type>&
newExporter);
1541 struct pack_functor {
1547 typedef typename DestOffsetViewType::non_const_value_type ScalarIndx;
1555 , src_offset(src_offset_)
1559 void operator()(
size_t row)
const {
1560 ScalarIndx
i = src_offset(row);
1561 ScalarIndx
j = dest_offset(row);
1562 const ScalarIndx
k = dest_offset(row + 1);
1563 for (;
j <
k;
j++,
i++) {
1571 template <
class CrsGraphType>
1572 friend Teuchos::RCP<CrsGraphType>
1573 importAndFillCompleteCrsGraph(
const Teuchos::RCP<const CrsGraphType>& sourceGraph,
1574 const Import<
typename CrsGraphType::local_ordinal_type,
1575 typename CrsGraphType::global_ordinal_type,
1576 typename CrsGraphType::node_type>& importer,
1577 const Teuchos::RCP<
const Map<
typename CrsGraphType::local_ordinal_type,
1578 typename CrsGraphType::global_ordinal_type,
1579 typename CrsGraphType::node_type>>& domainMap,
1580 const Teuchos::RCP<
const Map<
typename CrsGraphType::local_ordinal_type,
1581 typename CrsGraphType::global_ordinal_type,
1582 typename CrsGraphType::node_type>>& rangeMap,
1583 const Teuchos::RCP<Teuchos::ParameterList>& params);
1586 template <
class CrsGraphType>
1587 friend Teuchos::RCP<CrsGraphType>
1588 importAndFillCompleteCrsGraph(
const Teuchos::RCP<const CrsGraphType>& sourceGraph,
1589 const Import<
typename CrsGraphType::local_ordinal_type,
1590 typename CrsGraphType::global_ordinal_type,
1591 typename CrsGraphType::node_type>& rowImporter,
1592 const Import<
typename CrsGraphType::local_ordinal_type,
1593 typename CrsGraphType::global_ordinal_type,
1594 typename CrsGraphType::node_type>& domainImporter,
1595 const Teuchos::RCP<
const Map<
typename CrsGraphType::local_ordinal_type,
1596 typename CrsGraphType::global_ordinal_type,
1597 typename CrsGraphType::node_type>>& domainMap,
1598 const Teuchos::RCP<
const Map<
typename CrsGraphType::local_ordinal_type,
1599 typename CrsGraphType::global_ordinal_type,
1600 typename CrsGraphType::node_type>>& rangeMap,
1601 const Teuchos::RCP<Teuchos::ParameterList>& params);
1604 template <
class CrsGraphType>
1605 friend Teuchos::RCP<CrsGraphType>
1606 exportAndFillCompleteCrsGraph(
const Teuchos::RCP<const CrsGraphType>& sourceGraph,
1607 const Export<
typename CrsGraphType::local_ordinal_type,
1608 typename CrsGraphType::global_ordinal_type,
1609 typename CrsGraphType::node_type>& exporter,
1610 const Teuchos::RCP<
const Map<
typename CrsGraphType::local_ordinal_type,
1611 typename CrsGraphType::global_ordinal_type,
1612 typename CrsGraphType::node_type>>& domainMap,
1613 const Teuchos::RCP<
const Map<
typename CrsGraphType::local_ordinal_type,
1614 typename CrsGraphType::global_ordinal_type,
1615 typename CrsGraphType::node_type>>& rangeMap,
1616 const Teuchos::RCP<Teuchos::ParameterList>& params);
1619 template <
class CrsGraphType>
1620 friend Teuchos::RCP<CrsGraphType>
1621 exportAndFillCompleteCrsGraph(
const Teuchos::RCP<const CrsGraphType>& sourceGraph,
1622 const Export<
typename CrsGraphType::local_ordinal_type,
1623 typename CrsGraphType::global_ordinal_type,
1624 typename CrsGraphType::node_type>& rowExporter,
1625 const Export<
typename CrsGraphType::local_ordinal_type,
1626 typename CrsGraphType::global_ordinal_type,
1627 typename CrsGraphType::node_type>& domainExporter,
1628 const Teuchos::RCP<
const Map<
typename CrsGraphType::local_ordinal_type,
1629 typename CrsGraphType::global_ordinal_type,
1630 typename CrsGraphType::node_type>>& domainMap,
1631 const Teuchos::RCP<
const Map<
typename CrsGraphType::local_ordinal_type,
1632 typename CrsGraphType::global_ordinal_type,
1633 typename CrsGraphType::node_type>>& rangeMap,
1634 const Teuchos::RCP<Teuchos::ParameterList>& params);
1637 template <
class LO,
class GO,
class NT>
1640 Teuchos::Array<int>& remotePIDs,
1642 const CrsGraph<LO, GO, NT>& graph,
1643 const bool sortEachProcsGids,
1644 std::ostream* errStrm);
1663 importAndFillComplete(Teuchos::RCP<CrsGraph<local_ordinal_type, global_ordinal_type, Node>>& destGraph,
1665 const Teuchos::RCP<const map_type>& domainMap,
1666 const Teuchos::RCP<const map_type>& rangeMap,
1667 const Teuchos::RCP<Teuchos::ParameterList>& params = Teuchos::null)
const;
1685 importAndFillComplete(Teuchos::RCP<CrsGraph<local_ordinal_type, global_ordinal_type, Node>>& destGraph,
1688 const Teuchos::RCP<const map_type>& domainMap,
1689 const Teuchos::RCP<const map_type>& rangeMap,
1690 const Teuchos::RCP<Teuchos::ParameterList>& params)
const;
1708 exportAndFillComplete(Teuchos::RCP<CrsGraph<local_ordinal_type, global_ordinal_type, Node>>& destGraph,
1710 const Teuchos::RCP<const map_type>& domainMap = Teuchos::null,
1711 const Teuchos::RCP<const map_type>& rangeMap = Teuchos::null,
1712 const Teuchos::RCP<Teuchos::ParameterList>& params = Teuchos::null)
const;
1730 exportAndFillComplete(Teuchos::RCP<CrsGraph<local_ordinal_type, global_ordinal_type, Node>>& destGraph,
1733 const Teuchos::RCP<const map_type>& domainMap,
1734 const Teuchos::RCP<const map_type>& rangeMap,
1735 const Teuchos::RCP<Teuchos::ParameterList>& params)
const;
1759 transferAndFillComplete(Teuchos::RCP<CrsGraph<local_ordinal_type, global_ordinal_type, Node>>& destGraph,
1760 const ::Tpetra::Details::Transfer<local_ordinal_type, global_ordinal_type, Node>& rowTransfer,
1761 const Teuchos::RCP<const ::Tpetra::Details::Transfer<local_ordinal_type, global_ordinal_type, Node>>& domainTransfer,
1762 const Teuchos::RCP<const map_type>& domainMap = Teuchos::null,
1763 const Teuchos::RCP<const map_type>& rangeMap = Teuchos::null,
1764 const Teuchos::RCP<Teuchos::ParameterList>& params = Teuchos::null)
const;
1769 struct SLocalGlobalViews {
1770 Teuchos::ArrayView<const global_ordinal_type> ginds;
1771 Teuchos::ArrayView<const local_ordinal_type> linds;
1773 struct SLocalGlobalNCViews {
1774 Teuchos::ArrayView<global_ordinal_type> ginds;
1775 Teuchos::ArrayView<local_ordinal_type> linds;
1778 bool indicesAreAllocated()
const;
1781 allocateIndices(
const ELocalGlobal lg,
const bool verbose =
false);
1795 void makeColMap(Teuchos::Array<int>& remotePIDs);
1817 std::pair<size_t, std::string>
1830 const bool useRemotePIDs);
1872 const SLocalGlobalViews& newInds,
1873 const ELocalGlobal lg,
1874 const ELocalGlobal I);
1887 const size_t numInputInds);
1902 const size_t numInputInds,
1903 std::function<
void(
const size_t,
const size_t,
const size_t)> fun =
1904 std::function<
void(
const size_t,
const size_t,
const size_t)>());
1908 const Teuchos::ArrayView<const local_ordinal_type>& gblColInds,
1909 std::function<
void(
const size_t,
const size_t,
const size_t)> fun =
1910 std::function<
void(
const size_t,
const size_t,
const size_t)>());
1929 const Teuchos::ArrayView<const global_ordinal_type>& indices,
1930 std::function<
void(
const size_t,
const size_t,
const size_t)> fun)
const;
1969#ifdef KOKKOS_ENABLE_SERIAL
1970 !std::is_same<execution_space, Kokkos::Serial>::value;
1995 sortAndMergeAllIndices(
const bool sorted,
const bool merged);
2013 const Teuchos::RCP<const map_type>&
rangeMap);
2015 void staticAssertions()
const;
2016 void clearGlobalConstants();
2041 bool haveLocalOffRankOffsets()
const {
return haveLocalOffRankOffsets_; }
2095 void fillLocalGraph(
const Teuchos::RCP<Teuchos::ParameterList>& params);
2103 void swap(CrsGraph<local_ordinal_type, global_ordinal_type, Node>& graph);
2137 Teuchos::OrdinalTraits<size_t>::invalid();
2143 Teuchos::OrdinalTraits<global_size_t>::invalid();
2150 Teuchos::OrdinalTraits<global_size_t>::invalid();
2164 row_ptrs_device_view_type rowPtrsUnpacked_dev_;
2165 mutable row_ptrs_host_view_type rowPtrsUnpacked_host_;
2170 row_ptrs_device_view_type rowPtrsPacked_dev_;
2171 mutable row_ptrs_host_view_type rowPtrsPacked_host_;
2174 bool packedUnpackedRowPtrsMatch_ =
false;
2177 void setRowPtrsUnpacked(
const row_ptrs_device_view_type&
dview) {
2178 packedUnpackedRowPtrsMatch_ =
false;
2179 rowPtrsUnpacked_dev_ =
dview;
2181 rowPtrsUnpacked_host_ = row_ptrs_host_view_type();
2186 return rowPtrsUnpacked_dev_;
2191 if (rowPtrsUnpacked_host_.extent(0) != rowPtrsUnpacked_dev_.extent(0)) {
2196 if constexpr (std::is_same_v<typename Node::memory_space, Kokkos::HostSpace>) {
2197 rowPtrsUnpacked_host_ = rowPtrsUnpacked_dev_;
2200 typename row_ptrs_host_view_type::non_const_type
rowPtrsTemp(
2201 Kokkos::view_alloc(Kokkos::WithoutInitializing,
"rowPtrsUnpacked_host_"), rowPtrsUnpacked_dev_.extent(0));
2202 Kokkos::deep_copy(
rowPtrsTemp, rowPtrsUnpacked_dev_);
2206 if (packedUnpackedRowPtrsMatch_) {
2207 rowPtrsPacked_host_ = rowPtrsUnpacked_host_;
2210 return rowPtrsUnpacked_host_;
2213 void setRowPtrsPacked(
const row_ptrs_device_view_type&
dview) {
2214 packedUnpackedRowPtrsMatch_ =
false;
2215 rowPtrsPacked_dev_ =
dview;
2217 rowPtrsPacked_host_ = row_ptrs_host_view_type();
2222 return rowPtrsPacked_dev_;
2227 if (rowPtrsPacked_host_.extent(0) != rowPtrsPacked_dev_.extent(0)) {
2232 if constexpr (std::is_same_v<typename Node::memory_space, Kokkos::HostSpace>) {
2233 rowPtrsPacked_host_ = rowPtrsPacked_dev_;
2236 typename row_ptrs_host_view_type::non_const_type
rowPtrsTemp(
2237 Kokkos::view_alloc(Kokkos::WithoutInitializing,
"rowPtrsPacked_host_"), rowPtrsPacked_dev_.extent(0));
2238 Kokkos::deep_copy(
rowPtrsTemp, rowPtrsPacked_dev_);
2242 if (packedUnpackedRowPtrsMatch_) {
2243 rowPtrsUnpacked_host_ = rowPtrsPacked_host_;
2246 return rowPtrsPacked_host_;
2253 void setRowPtrs(
const row_ptrs_device_view_type&
dview) {
2254 packedUnpackedRowPtrsMatch_ =
true;
2255 rowPtrsUnpacked_dev_ =
dview;
2256 rowPtrsPacked_dev_ =
dview;
2258 rowPtrsUnpacked_host_ = row_ptrs_host_view_type();
2259 rowPtrsPacked_host_ = row_ptrs_host_view_type();
2312 typename local_inds_dualv_type::t_host::const_type
2318 typename local_inds_dualv_type::t_dev::const_type
2324 typename global_inds_dualv_type::t_host::const_type
2330 typename global_inds_dualv_type::t_dev::const_type
2336 typename local_inds_dualv_type::t_host
2368 typename Kokkos::View<const size_t*, device_type>::host_mirror_type
2453 Details::STORAGE_1D_UNPACKED;
2455 bool indicesAreAllocated_ =
false;
2456 bool indicesAreLocal_ =
false;
2457 bool indicesAreGlobal_ =
false;
2458 bool fillComplete_ =
false;
2470 mutable bool haveLocalOffRankOffsets_ =
false;
2472 typedef typename std::map<global_ordinal_type, std::vector<global_ordinal_type>> nonlocals_type;
2495 static bool getDebug();
2499 bool debug_ = getDebug();
2502 static bool getVerbose();
2507 bool verbose_ = getVerbose();
2511 mutable bool need_sync_host_uvm_access =
false;
2514 void set_need_sync_host_uvm_access() {
2515 need_sync_host_uvm_access =
true;
2519 void execute_sync_host_uvm_access()
const {
2520 if (need_sync_host_uvm_access) {
2521 Kokkos::fence(
"CrsGraph::execute_sync_host_uvm_access");
2522 need_sync_host_uvm_access =
false;
2534template <
class LocalOrdinal,
class GlobalOrdinal,
class Node>
2535Teuchos::RCP<CrsGraph<LocalOrdinal, GlobalOrdinal, Node>>
2540 const Teuchos::RCP<Teuchos::ParameterList>&
params =
2597template <
class CrsGraphType>
2598Teuchos::RCP<CrsGraphType>
2600 const Import<
typename CrsGraphType::local_ordinal_type,
2601 typename CrsGraphType::global_ordinal_type,
2602 typename CrsGraphType::node_type>&
importer,
2603 const Teuchos::RCP<
const Map<
typename CrsGraphType::local_ordinal_type,
2604 typename CrsGraphType::global_ordinal_type,
2605 typename CrsGraphType::node_type>>& domainMap = Teuchos::null,
2606 const Teuchos::RCP<
const Map<
typename CrsGraphType::local_ordinal_type,
2607 typename CrsGraphType::global_ordinal_type,
2608 typename CrsGraphType::node_type>>&
rangeMap = Teuchos::null,
2609 const Teuchos::RCP<Teuchos::ParameterList>&
params = Teuchos::null) {
2665template <
class CrsGraphType>
2666Teuchos::RCP<CrsGraphType>
2668 const Import<
typename CrsGraphType::local_ordinal_type,
2669 typename CrsGraphType::global_ordinal_type,
2671 const Import<
typename CrsGraphType::local_ordinal_type,
2672 typename CrsGraphType::global_ordinal_type,
2674 const Teuchos::RCP<
const Map<
typename CrsGraphType::local_ordinal_type,
2675 typename CrsGraphType::global_ordinal_type,
2676 typename CrsGraphType::node_type>>& domainMap,
2677 const Teuchos::RCP<
const Map<
typename CrsGraphType::local_ordinal_type,
2678 typename CrsGraphType::global_ordinal_type,
2679 typename CrsGraphType::node_type>>&
rangeMap,
2680 const Teuchos::RCP<Teuchos::ParameterList>&
params) {
2719template <
class CrsGraphType>
2720Teuchos::RCP<CrsGraphType>
2722 const Export<
typename CrsGraphType::local_ordinal_type,
2723 typename CrsGraphType::global_ordinal_type,
2724 typename CrsGraphType::node_type>&
exporter,
2725 const Teuchos::RCP<
const Map<
typename CrsGraphType::local_ordinal_type,
2726 typename CrsGraphType::global_ordinal_type,
2727 typename CrsGraphType::node_type>>& domainMap = Teuchos::null,
2728 const Teuchos::RCP<
const Map<
typename CrsGraphType::local_ordinal_type,
2729 typename CrsGraphType::global_ordinal_type,
2730 typename CrsGraphType::node_type>>&
rangeMap = Teuchos::null,
2731 const Teuchos::RCP<Teuchos::ParameterList>&
params = Teuchos::null) {
2770template <
class CrsGraphType>
2771Teuchos::RCP<CrsGraphType>
2773 const Export<
typename CrsGraphType::local_ordinal_type,
2774 typename CrsGraphType::global_ordinal_type,
2776 const Export<
typename CrsGraphType::local_ordinal_type,
2777 typename CrsGraphType::global_ordinal_type,
2779 const Teuchos::RCP<
const Map<
typename CrsGraphType::local_ordinal_type,
2780 typename CrsGraphType::global_ordinal_type,
2781 typename CrsGraphType::node_type>>& domainMap,
2782 const Teuchos::RCP<
const Map<
typename CrsGraphType::local_ordinal_type,
2783 typename CrsGraphType::global_ordinal_type,
2784 typename CrsGraphType::node_type>>&
rangeMap,
2785 const Teuchos::RCP<Teuchos::ParameterList>&
params) {
Forward declaration of Tpetra::BlockCrsMatrix.
Forward declaration of Tpetra::CrsGraph.
Forward declaration of Tpetra::CrsMatrix.
Stand-alone utility functions and macros.
A distributed graph accessed by rows (adjacency lists) and stored sparsely.
bool isMerged() const
Whether duplicate column indices in each row have been merged.
virtual void unpackAndCombine(const Kokkos::DualView< const local_ordinal_type *, buffer_device_type > &importLIDs, Kokkos::DualView< packet_type *, buffer_device_type > imports, Kokkos::DualView< size_t *, buffer_device_type > numPacketsPerLID, const size_t constantNumPackets, const CombineMode combineMode) override
local_inds_dualv_type::t_dev::const_type getLocalIndsViewDevice(const RowInfo &rowinfo) const
Get a const, locally indexed view of the locally owned row myRow, such that rowinfo = getRowInfo(myRo...
global_size_t globalMaxNumRowEntries_
Global maximum of the number of entries in each row.
void reindexColumns(const Teuchos::RCP< const map_type > &newColMap, const Teuchos::RCP< const import_type > &newImport=Teuchos::null, const bool sortIndicesInEachRow=true)
Reindex the column indices in place, and replace the column Map. Optionally, replace the Import objec...
Kokkos::View< size_t *, Kokkos::LayoutLeft, device_type >::host_mirror_type num_row_entries_type
Row offsets for "1-D" storage.
global_inds_dualv_type::t_host::const_type getGlobalIndsViewHost(const RowInfo &rowinfo) const
Get a const, globally indexed view of the locally owned row myRow, such that rowinfo = getRowInfo(myR...
size_t getNumEntriesInLocalRow(local_ordinal_type localRow) const override
Get the number of entries in the given row (local index).
Teuchos::RCP< CrsGraphType > importAndFillCompleteCrsGraph(const Teuchos::RCP< const CrsGraphType > &sourceGraph, const Import< typename CrsGraphType::local_ordinal_type, typename CrsGraphType::global_ordinal_type, typename CrsGraphType::node_type > &rowImporter, const Import< typename CrsGraphType::local_ordinal_type, typename CrsGraphType::global_ordinal_type, typename CrsGraphType::node_type > &domainImporter, const Teuchos::RCP< const Map< typename CrsGraphType::local_ordinal_type, typename CrsGraphType::global_ordinal_type, typename CrsGraphType::node_type > > &domainMap, const Teuchos::RCP< const Map< typename CrsGraphType::local_ordinal_type, typename CrsGraphType::global_ordinal_type, typename CrsGraphType::node_type > > &rangeMap, const Teuchos::RCP< Teuchos::ParameterList > ¶ms)
Nonmember CrsGraph constructor that fuses Import and fillComplete().
Teuchos::RCP< const map_type > getColMap() const override
Returns the Map that describes the column distribution in this graph.
Teuchos::RCP< const Teuchos::ParameterList > getValidParameters() const override
Default parameter list suitable for validation.
Details::EStorageStatus storageStatus_
Status of the graph's storage, when not in a fill-complete state.
::Tpetra::Import< LocalOrdinal, GlobalOrdinal, Node > import_type
The Import specialization used by this class.
global_ordinal_type packet_type
Type of each entry of the DistObject communication buffer.
GlobalOrdinal global_ordinal_type
The type of the graph's global indices.
void insertGlobalIndicesIntoNonownedRows(const global_ordinal_type gblRow, const global_ordinal_type gblColInds[], const local_ordinal_type numGblColInds)
Implementation of insertGlobalIndices for nonowned rows.
Teuchos::RCP< const map_type > rangeMap_
The Map describing the range of the (matrix corresponding to the) graph.
std::pair< size_t, std::string > makeIndicesLocal(const bool verbose=false)
Convert column indices from global to local.
local_inds_device_view_type getLocalIndicesDevice() const
Get a device view of the packed column indicies.
global_size_t getGlobalNumEntries() const override
Returns the global number of entries in the graph.
bool isIdenticalTo(const CrsGraph< LocalOrdinal, GlobalOrdinal, Node > &graph) const
Create a cloned CrsGraph for a different Node type.
Teuchos::RCP< const Teuchos::Comm< int > > getComm() const override
Returns the communicator.
local_inds_wdv_type lclIndsUnpacked_wdv
Local ordinals of column indices for all rows Valid when isLocallyIndexed is true If OptimizedStorage...
bool haveGlobalConstants() const
Returns true if globalConstants have been computed; false otherwise.
void globalAssemble()
Communicate nonlocal contributions to other processes.
RowInfo getRowInfoFromGlobalRowIndex(const global_ordinal_type gblRow) const
Get information about the locally owned row with global index gblRow.
void getLocalDiagOffsets(const Kokkos::View< size_t *, device_type, Kokkos::MemoryUnmanaged > &offsets) const
Get offsets of the diagonal entries in the graph.
size_t findGlobalIndices(const RowInfo &rowInfo, const Teuchos::ArrayView< const global_ordinal_type > &indices, std::function< void(const size_t, const size_t, const size_t)> fun) const
Finds indices in the given row.
CrsGraph(const CrsGraph< local_ordinal_type, global_ordinal_type, node_type > &)=default
Copy constructor (default).
void fillComplete(const Teuchos::RCP< const map_type > &domainMap, const Teuchos::RCP< const map_type > &rangeMap, const Teuchos::RCP< Teuchos::ParameterList > ¶ms=Teuchos::null)
Tell the graph that you are done changing its structure.
global_inds_wdv_type gblInds_wdv
Global ordinals of column indices for all rows.
size_t nodeMaxNumRowEntries_
Local maximum of the number of entries in each row.
Teuchos::RCP< const import_type > importer_
The Import from the domain Map to the column Map.
Teuchos::RCP< CrsGraphType > exportAndFillCompleteCrsGraph(const Teuchos::RCP< const CrsGraphType > &sourceGraph, const Export< typename CrsGraphType::local_ordinal_type, typename CrsGraphType::global_ordinal_type, typename CrsGraphType::node_type > &exporter, const Teuchos::RCP< const Map< typename CrsGraphType::local_ordinal_type, typename CrsGraphType::global_ordinal_type, typename CrsGraphType::node_type > > &domainMap=Teuchos::null, const Teuchos::RCP< const Map< typename CrsGraphType::local_ordinal_type, typename CrsGraphType::global_ordinal_type, typename CrsGraphType::node_type > > &rangeMap=Teuchos::null, const Teuchos::RCP< Teuchos::ParameterList > ¶ms=Teuchos::null)
Nonmember CrsGraph constructor that fuses Export and fillComplete().
num_row_entries_type k_numRowEntries_
The number of local entries in each locally owned row.
CrsGraph(CrsGraph< local_ordinal_type, global_ordinal_type, node_type > &&)=default
Move constructor (default).
const row_ptrs_device_view_type & getRowPtrsUnpackedDevice() const
Get the unpacked row pointers on device.
size_t numAllocForAllRows_
The maximum number of entries to allow in each locally owned row.
bool hasColMap() const override
Whether the graph has a column Map.
LocalOrdinal local_ordinal_type
The type of the graph's local indices.
std::string description() const override
Return a one-line human-readable description of this object.
bool isStorageOptimized() const
Returns true if storage has been optimized.
void getGlobalRowCopy(global_ordinal_type gblRow, nonconst_global_inds_host_view_type &gblColInds, size_t &numColInds) const override
Get a copy of the given row, using global indices.
void removeLocalIndices(local_ordinal_type localRow)
Remove all graph indices from the specified local row.
void importAndFillComplete(Teuchos::RCP< CrsGraph< local_ordinal_type, global_ordinal_type, Node > > &destGraph, const import_type &importer, const Teuchos::RCP< const map_type > &domainMap, const Teuchos::RCP< const map_type > &rangeMap, const Teuchos::RCP< Teuchos::ParameterList > ¶ms=Teuchos::null) const
Import from this to the given destination graph, and make the result fill complete.
global_size_t getGlobalNumRows() const override
Returns the number of global rows in the graph.
Teuchos::RCP< const map_type > getDomainMap() const override
Returns the Map associated with the domain of this graph.
void replaceRangeMapAndExporter(const Teuchos::RCP< const map_type > &newRangeMap, const Teuchos::RCP< const export_type > &newExporter)
Replace the current Range Map and Export with the given parameters.
void computeLocalConstants()
Compute local constants, if they have not yet been computed.
void describe(Teuchos::FancyOStream &out, const Teuchos::EVerbosityLevel verbLevel=Teuchos::Describable::verbLevel_default) const override
Print this object to the given output stream with the given verbosity level.
typename local_graph_device_type::host_mirror_type local_graph_host_type
The type of the part of the sparse graph on each MPI process.
void setParameterList(const Teuchos::RCP< Teuchos::ParameterList > ¶ms) override
Set the given list of parameters (must be nonnull).
static const bool useAtomicUpdatesByDefault
Whether transformLocalValues should use atomic updates by default.
void resumeFill(const Teuchos::RCP< Teuchos::ParameterList > ¶ms=Teuchos::null)
Resume fill operations.
size_t insertIndices(RowInfo &rowInfo, const SLocalGlobalViews &newInds, const ELocalGlobal lg, const ELocalGlobal I)
Insert indices into the given row.
typename Node::device_type device_type
This class' Kokkos device type.
Teuchos::RCP< CrsGraphType > importAndFillCompleteCrsGraph(const Teuchos::RCP< const CrsGraphType > &sourceGraph, const Import< typename CrsGraphType::local_ordinal_type, typename CrsGraphType::global_ordinal_type, typename CrsGraphType::node_type > &importer, const Teuchos::RCP< const Map< typename CrsGraphType::local_ordinal_type, typename CrsGraphType::global_ordinal_type, typename CrsGraphType::node_type > > &domainMap=Teuchos::null, const Teuchos::RCP< const Map< typename CrsGraphType::local_ordinal_type, typename CrsGraphType::global_ordinal_type, typename CrsGraphType::node_type > > &rangeMap=Teuchos::null, const Teuchos::RCP< Teuchos::ParameterList > ¶ms=Teuchos::null)
Nonmember CrsGraph constructor that fuses Import and fillComplete().
void insertGlobalIndicesFiltered(const local_ordinal_type lclRow, const global_ordinal_type gblColInds[], const local_ordinal_type numGblColInds)
Like insertGlobalIndices(), but with column Map filtering.
virtual void copyAndPermute(const SrcDistObject &source, const size_t numSameIDs, const Kokkos::DualView< const local_ordinal_type *, buffer_device_type > &permuteToLIDs, const Kokkos::DualView< const local_ordinal_type *, buffer_device_type > &permuteFromLIDs, const CombineMode CM) override
RowInfo getRowInfo(const local_ordinal_type myRow) const
Get information about the locally owned row with local index myRow.
global_inds_dualv_type::t_dev::const_type getGlobalIndsViewDevice(const RowInfo &rowinfo) const
Get a const, globally indexed view of the locally owned row myRow, such that rowinfo = getRowInfo(myR...
KokkosSparse::StaticCrsGraph< local_ordinal_type, Kokkos::LayoutLeft, device_type, void, size_t > local_graph_device_type
The type of the part of the sparse graph on each MPI process.
Teuchos::RCP< const map_type > colMap_
The Map describing the distribution of columns of the graph.
bool noRedundancies_
Whether the graph's indices are non-redundant (merged) in each row, on this process.
row_ptrs_host_view_type getLocalRowPtrsHost() const
Get a host view of the packed row offsets.
bool isSorted() const
Whether graph indices in all rows are known to be sorted.
Teuchos::RCP< CrsGraph< LocalOrdinal, GlobalOrdinal, Node > > createCrsGraph(const Teuchos::RCP< const Map< LocalOrdinal, GlobalOrdinal, Node > > &map, size_t maxNumEntriesPerRow=0, const Teuchos::RCP< Teuchos::ParameterList > ¶ms=Teuchos::null)
Nonmember function to create an empty CrsGraph given a row Map and the max number of entries allowed ...
void setAllIndices(const typename local_graph_device_type::row_map_type &rowPointers, const typename local_graph_device_type::entries_type::non_const_type &columnIndices)
Set the graph's data directly, using 1-D storage.
void insertLocalIndices(const local_ordinal_type localRow, const Teuchos::ArrayView< const local_ordinal_type > &indices)
Insert local indices into the graph.
local_inds_host_view_type getLocalIndicesHost() const
Get a host view of the packed column indicies.
bool supportsRowViews() const override
Whether this class implements getLocalRowView() and getGlobalRowView() (it does).
size_t getNumEntriesInGlobalRow(global_ordinal_type globalRow) const override
Returns the current number of entries on this node in the specified global row.
bool isFillComplete() const override
Whether fillComplete() has been called and the graph is in compute mode.
void setDomainRangeMaps(const Teuchos::RCP< const map_type > &domainMap, const Teuchos::RCP< const map_type > &rangeMap)
void swap(CrsGraph< local_ordinal_type, global_ordinal_type, Node > &graph)
Swaps the data from *this with the data and maps from graph.
CrsGraph & operator=(const CrsGraph< local_ordinal_type, global_ordinal_type, node_type > &)=default
Assignment operator (default).
void getLocalRowCopy(local_ordinal_type lclRow, nonconst_local_inds_host_view_type &lclColInds, size_t &numColInds) const override
Get a copy of the given row, using local indices.
void getGlobalRowView(const global_ordinal_type gblRow, global_inds_host_view_type &gblColInds) const override
Get a const view of the given global row's global column indices.
const row_ptrs_host_view_type & getRowPtrsUnpackedHost() const
Get the unpacked row pointers on host. Lazily make a copy from device.
void exportAndFillComplete(Teuchos::RCP< CrsGraph< local_ordinal_type, global_ordinal_type, Node > > &destGraph, const export_type &exporter, const Teuchos::RCP< const map_type > &domainMap=Teuchos::null, const Teuchos::RCP< const map_type > &rangeMap=Teuchos::null, const Teuchos::RCP< Teuchos::ParameterList > ¶ms=Teuchos::null) const
Export from this to the given destination graph, and make the result fill complete.
void makeColMap(Teuchos::Array< int > &remotePIDs)
Make and set the graph's column Map.
bool haveGlobalConstants_
Whether all processes have computed global constants.
size_t getGlobalMaxNumRowEntries() const override
Maximum number of entries in any row of the graph, over all processes in the graph's communicator.
void checkInternalState() const
Throw an exception if the internal state is not consistent.
typename dist_object_type::buffer_device_type buffer_device_type
Kokkos::Device specialization for communication buffers.
Teuchos::RCP< const map_type > getRangeMap() const override
Returns the Map associated with the domain of this graph.
typename row_graph_type::global_inds_device_view_type global_inds_device_view_type
The Kokkos::View type for views of global ordinals on device and host.
void expertStaticFillComplete(const Teuchos::RCP< const map_type > &domainMap, const Teuchos::RCP< const map_type > &rangeMap, const Teuchos::RCP< const import_type > &importer=Teuchos::null, const Teuchos::RCP< const export_type > &exporter=Teuchos::null, const Teuchos::RCP< Teuchos::ParameterList > ¶ms=Teuchos::null)
Perform a fillComplete on a graph that already has data, via setAllIndices().
bool sortGhostsAssociatedWithEachProcessor_
Whether to require makeColMap() (and therefore fillComplete()) to order column Map GIDs associated wi...
size_t getNumAllocatedEntriesInGlobalRow(global_ordinal_type globalRow) const
Current number of allocated entries in the given row on the calling (MPI) process,...
Teuchos::RCP< const export_type > getExporter() const override
Returns the exporter associated with this graph.
typename device_type::execution_space execution_space
This class' Kokkos execution space.
void makeImportExport(Teuchos::Array< int > &remotePIDs, const bool useRemotePIDs)
Make the Import and Export objects, if needed.
global_ordinal_type getIndexBase() const override
Returns the index base for global indices for this graph.
row_ptrs_device_view_type getLocalRowPtrsDevice() const
Get a device view of the packed row offsets.
local_inds_dualv_type::t_host::const_type getLocalIndsViewHost(const RowInfo &rowinfo) const
Get a const, locally indexed view of the locally owned row myRow, such that rowinfo = getRowInfo(myRo...
bool isFillActive() const
Whether resumeFill() has been called and the graph is in edit mode.
Teuchos::RCP< const map_type > getRowMap() const override
Returns the Map that describes the row distribution in this graph.
global_size_t globalNumEntries_
Global number of entries in the graph.
size_t insertGlobalIndicesImpl(const local_ordinal_type lclRow, const global_ordinal_type inputGblColInds[], const size_t numInputInds)
Insert global indices, using an input local row index.
::Tpetra::Export< LocalOrdinal, GlobalOrdinal, Node > export_type
The Export specialization used by this class.
size_t getLocalNumEntries() const override
The local number of entries in the graph.
Teuchos::RCP< const import_type > getImporter() const override
Returns the importer associated with this graph.
local_inds_wdv_type lclIndsPacked_wdv
Local ordinals of column indices for all rows Valid when isLocallyIndexed is true Built during fillCo...
Teuchos::RCP< const map_type > domainMap_
The Map describing the domain of the (matrix corresponding to the) graph.
const row_ptrs_host_view_type & getRowPtrsPackedHost() const
Get the packed row pointers on host. Lazily make a copy from device.
size_t getLocalNumCols() const override
Returns the number of columns connected to the locally owned rows of this graph.
nonlocals_type nonlocals_
Nonlocal data given to insertGlobalIndices.
virtual void pack(const Teuchos::ArrayView< const local_ordinal_type > &exportLIDs, Teuchos::Array< global_ordinal_type > &exports, const Teuchos::ArrayView< size_t > &numPacketsPerLID, size_t &constantNumPackets) const override
void getLocalOffRankOffsets(offset_device_view_type &offsets) const
Get offsets of the off-rank entries in the graph.
global_size_t getGlobalNumCols() const override
Returns the number of global columns in the graph.
typename row_graph_type::local_inds_device_view_type local_inds_device_view_type
The Kokkos::View type for views of local ordinals on device and host.
Kokkos::View< constsize_t *, device_type >::host_mirror_type k_numAllocPerRow_
The maximum number of entries to allow in each locally owned row, per row.
bool indicesAreSorted_
Whether the graph's indices are sorted in each row, on this process.
Node node_type
This class' Kokkos Node type.
Teuchos::RCP< const export_type > exporter_
The Export from the row Map to the range Map.
void insertGlobalIndices(const global_ordinal_type globalRow, const Teuchos::ArrayView< const global_ordinal_type > &indices)
Insert global indices into the graph.
local_inds_dualv_type::t_host getLocalIndsViewHostNonConst(const RowInfo &rowinfo)
Get a ReadWrite locally indexed view of the locally owned row myRow, such that rowinfo = getRowInfo(m...
void replaceDomainMap(const Teuchos::RCP< const map_type > &newDomainMap)
Replace the current domain Map with the given objects.
CrsGraph & operator=(CrsGraph< local_ordinal_type, global_ordinal_type, node_type > &&)=default
Move assignment (default).
void computeGlobalConstants()
Compute global constants, if they have not yet been computed.
size_t getNumAllocatedEntriesInLocalRow(local_ordinal_type localRow) const
Current number of allocated entries in the given row on the calling (MPI) process,...
virtual ~CrsGraph()=default
Destructor (virtual for memory safety of derived classes).
offset_device_view_type k_offRankOffsets_
The offsets for off-rank entries.
void replaceDomainMapAndImporter(const Teuchos::RCP< const map_type > &newDomainMap, const Teuchos::RCP< const import_type > &newImporter)
Replace the current domain Map and Import with the given parameters.
void setLocallyModified()
Report that we made a local modification to its structure.
size_t getLocalAllocationSize() const
The local number of indices allocated for the graph, over all rows on the calling (MPI) process.
void replaceRangeMap(const Teuchos::RCP< const map_type > &newRangeMap)
Replace the current Range Map with the given objects.
Teuchos::RCP< const map_type > rowMap_
The Map describing the distribution of rows of the graph.
Teuchos::RCP< CrsGraphType > exportAndFillCompleteCrsGraph(const Teuchos::RCP< const CrsGraphType > &sourceGraph, const Export< typename CrsGraphType::local_ordinal_type, typename CrsGraphType::global_ordinal_type, typename CrsGraphType::node_type > &rowExporter, const Export< typename CrsGraphType::local_ordinal_type, typename CrsGraphType::global_ordinal_type, typename CrsGraphType::node_type > &domainExporter, const Teuchos::RCP< const Map< typename CrsGraphType::local_ordinal_type, typename CrsGraphType::global_ordinal_type, typename CrsGraphType::node_type > > &domainMap, const Teuchos::RCP< const Map< typename CrsGraphType::local_ordinal_type, typename CrsGraphType::global_ordinal_type, typename CrsGraphType::node_type > > &rangeMap, const Teuchos::RCP< Teuchos::ParameterList > ¶ms)
Nonmember CrsGraph constructor that fuses Export and fillComplete().
const row_ptrs_device_view_type & getRowPtrsPackedDevice() const
Get the packed row pointers on device.
virtual void removeEmptyProcessesInPlace(const Teuchos::RCP< const map_type > &newMap) override
Remove processes owning zero rows from the Maps and their communicator.
void getLocalRowView(const LocalOrdinal lclRow, local_inds_host_view_type &lclColInds) const override
Get a const view of the given local row's local column indices.
bool isGloballyIndexed() const override
Whether the graph's column indices are stored as global indices.
bool isLocallyIndexed() const override
Whether the graph's column indices are stored as local indices.
size_t getLocalMaxNumRowEntries() const override
Maximum number of entries in any row of the graph, on this process.
virtual bool checkSizes(const SrcDistObject &source) override
Compare the source and target (this) objects for compatibility.
local_graph_device_type getLocalGraphDevice() const
Get the local graph.
size_t getLocalNumRows() const override
Returns the number of graph rows owned on the calling node.
void replaceColMap(const Teuchos::RCP< const map_type > &newColMap)
Replace the graph's current column Map with the given Map.
bool haveLocalConstants_
Whether this process has computed local constants.
Sparse matrix that presents a row-oriented interface that lets users read or modify entries.
Struct that holds views of the contents of a CrsMatrix.
Keep track of how much more space a CrsGraph or CrsMatrix needs, when the graph or matrix is the targ...
Base class for distributed Tpetra objects that support data redistribution.
virtual void packAndPrepare(const SrcDistObject &source, const Kokkos::DualView< const local_ordinal_type *, buffer_device_type > &exportLIDs, Kokkos::DualView< packet_type *, buffer_device_type > &exports, Kokkos::DualView< size_t *, buffer_device_type > numPacketsPerLID, size_t &constantNumPackets)
Pack data and metadata for communication (sends).
Kokkos::Device< typename device_type::execution_space, buffer_memory_space > buffer_device_type
Kokkos::Device specialization for communication buffers.
virtual void unpackAndCombine(const Kokkos::DualView< const local_ordinal_type *, buffer_device_type > &importLIDs, Kokkos::DualView< packet_type *, buffer_device_type > imports, Kokkos::DualView< size_t *, buffer_device_type > numPacketsPerLID, const size_t constantNumPackets, const CombineMode combineMode)
Perform any unpacking and combining after communication.
Communication plan for data redistribution from a (possibly) multiply-owned to a uniquely-owned distr...
A distributed graph accessed by rows (adjacency lists) and stored sparsely.
Communication plan for data redistribution from a uniquely-owned to a (possibly) multiply-owned distr...
A parallel distribution of indices over processes.
An abstract interface for graphs accessed by rows.
Abstract base class for objects that can be the source of an Import or Export operation.
Implementation details of Tpetra.
int makeColMap(Teuchos::RCP< const Tpetra::Map< LO, GO, NT > > &colMap, Teuchos::Array< int > &remotePIDs, const Teuchos::RCP< const Tpetra::Map< LO, GO, NT > > &domMap, const CrsGraph< LO, GO, NT > &graph, const bool sortEachProcsGids=true, std::ostream *errStrm=NULL)
Make the graph's column Map.
EStorageStatus
Status of the graph's or matrix's storage, when not in a fill-complete state.
Namespace Tpetra contains the class and methods constituting the Tpetra library.
CombineMode
Rule for combining data in an Import or Export.
Allocation information for a locally owned row in a CrsGraph or CrsMatrix.