12#include <dolfinx/graph/AdjacencyList.h> 
   61std::tuple<std::int64_t, std::vector<std::int32_t>,
 
   62           std::vector<std::vector<std::int64_t>>,
 
   63           std::vector<std::vector<int>>>
 
   65    const std::vector<std::pair<std::reference_wrapper<const IndexMap>, 
int>>&
 
   87    const IndexMap& imap, std::span<const std::int32_t> indices,
 
  138           std::span<const std::int64_t> 
ghosts, std::span<const int> 
owners,
 
  139           int tag = 
static_cast<int>(dolfinx::MPI::tag::consensus_nbx));
 
  161           const std::array<std::vector<int>, 2>& src_dest,
 
  162           std::span<const std::int64_t> 
ghosts, std::span<const int> 
owners);
 
  180  std::array<std::int64_t, 2> 
local_range() const noexcept;
 
  193  std::span<const std::int64_t> 
ghosts() const noexcept;
 
  197  MPI_Comm 
comm() const;
 
  203                       std::span<std::int64_t> global) const;
 
  211                       std::span<std::int32_t> local) const;
 
  221  std::span<const 
int> 
owners()
 const { 
return _owners; }
 
  236      int tag = 
static_cast<int>(dolfinx::MPI::tag::consensus_nbx)) 
const;
 
  250  std::span<const int> 
src() const noexcept;
 
  259  std::span<const 
int> 
dest() const noexcept;
 
  310  std::array<std::vector<
int>, 2> 
rank_type(
int split_type) const;
 
  314  std::array<std::int64_t, 2> _local_range;
 
  317  std::int64_t _size_global;
 
  323  std::vector<std::int64_t> _ghosts;
 
  326  std::vector<
int> _owners;
 
  329  std::vector<
int> _src;
 
  332  std::vector<
int> _dest;
 
 
std::vector< std::int32_t > weights_dest() const
Compute the number of ghost indices owned by each rank in IndexMap::dest.
Definition IndexMap.cpp:1319
 
~IndexMap()=default
Destructor.
 
std::span< const int > owners() const
The ranks that own each ghost index.
Definition IndexMap.h:221
 
std::int32_t num_ghosts() const noexcept
Number of ghost indices on this process.
Definition IndexMap.cpp:931
 
std::span< const int > dest() const noexcept
Ordered set of MPI ranks that ghost indices owned by caller.
Definition IndexMap.cpp:1302
 
std::vector< std::int32_t > weights_src() const
Compute the number of ghost indices owned by each rank in IndexMap::src.
Definition IndexMap.cpp:1304
 
std::array< std::int64_t, 2 > local_range() const noexcept
Range of indices (global) owned by this process.
Definition IndexMap.cpp:926
 
std::int32_t size_local() const noexcept
Number of indices owned by this process.
Definition IndexMap.cpp:933
 
std::int64_t size_global() const noexcept
Number indices across communicator.
Definition IndexMap.cpp:938
 
IndexMap(IndexMap &&map)=default
Move constructor.
 
IndexMap & operator=(IndexMap &&map)=default
Move assignment.
 
std::span< const int > src() const noexcept
Ordered set of MPI ranks that own caller's ghost indices.
Definition IndexMap.cpp:1300
 
void local_to_global(std::span< const std::int32_t > local, std::span< std::int64_t > global) const
Compute global indices for array of local indices.
Definition IndexMap.cpp:945
 
void global_to_local(std::span< const std::int64_t > global, std::span< std::int32_t > local) const
Compute local indices for array of global indices.
Definition IndexMap.cpp:964
 
IndexMap(MPI_Comm comm, std::int32_t local_size)
Create an non-overlapping index map.
Definition IndexMap.cpp:856
 
std::span< const std::int64_t > ghosts() const noexcept
Definition IndexMap.cpp:940
 
graph::AdjacencyList< int > index_to_dest_ranks(int tag=static_cast< int >(dolfinx::MPI::tag::consensus_nbx)) const
Compute map from each local (owned) index to the set of ranks that have the index as a ghost.
Definition IndexMap.cpp:1007
 
std::vector< std::int32_t > shared_indices() const
Build a list of owned indices that are ghosted by another rank.
Definition IndexMap.cpp:1229
 
MPI_Comm comm() const
Return the MPI communicator that the map is defined on.
Definition IndexMap.cpp:1005
 
std::vector< std::int64_t > global_indices() const
Build list of indices with global indexing.
Definition IndexMap.cpp:993
 
std::array< std::vector< int >, 2 > rank_type(int split_type) const
Destination and source ranks by type, e.g, ranks that are destination/source ranks for the caller and...
Definition IndexMap.cpp:1347
 
This class provides a static adjacency list data structure.
Definition AdjacencyList.h:38
 
MPI support functionality.
Definition MPI.h:30
 
Miscellaneous classes, functions and types.
Definition dolfinx_common.h:8
 
std::pair< IndexMap, std::vector< std::int32_t > > create_sub_index_map(const IndexMap &imap, std::span< const std::int32_t > indices, IndexMapOrder order=IndexMapOrder::any, bool allow_owner_change=false)
Create a new index map from a subset of indices in an existing index map.
Definition IndexMap.cpp:816
 
std::vector< int32_t > compute_owned_indices(std::span< const std::int32_t > indices, const IndexMap &map)
Given a sorted list of indices (local indexing, owned or ghost) and an index map, this function retur...
Definition IndexMap.cpp:538
 
IndexMapOrder
Definition IndexMap.h:27
 
@ any
Allow arbitrary ordering of ghost indices in sub-maps.
Definition IndexMap.h:29
 
@ preserve
Preserve the ordering of ghost indices.
Definition IndexMap.h:28
 
std::tuple< std::int64_t, std::vector< std::int32_t >, std::vector< std::vector< std::int64_t > >, std::vector< std::vector< int > > > stack_index_maps(const std::vector< std::pair< std::reference_wrapper< const IndexMap >, int > > &maps)
Compute layout data and ghost indices for a stacked (concatenated) index map, i.e....
Definition IndexMap.cpp:650
 
Top-level namespace.
Definition defines.h:12