DOLFINx 0.10.0.0
DOLFINx C++ interface
Loading...
Searching...
No Matches
IndexMap.h
1// Copyright (C) 2015-2024 Chris Richardson, Garth N. Wells and Igor Baratta
2//
3// This file is part of DOLFINx (https://www.fenicsproject.org)
4//
5// SPDX-License-Identifier: LGPL-3.0-or-later
6
7#pragma once
8
9#include "IndexMap.h"
10#include "MPI.h"
11#include <cstdint>
12#include <dolfinx/graph/AdjacencyList.h>
13#include <memory>
14#include <span>
15#include <tuple>
16#include <utility>
17#include <vector>
18
19namespace dolfinx::common
20{
21// Forward declaration
22class IndexMap;
23
26enum class IndexMapOrder : bool
27{
28 preserve = true,
29 any = false
30};
31
39std::vector<int32_t>
40compute_owned_indices(std::span<const std::int32_t> indices,
41 const IndexMap& map);
42
60std::tuple<std::int64_t, std::vector<std::int32_t>,
61 std::vector<std::vector<std::int64_t>>,
62 std::vector<std::vector<int>>>
64 const std::vector<std::pair<std::reference_wrapper<const IndexMap>, int>>&
65 maps);
66
85std::pair<IndexMap, std::vector<std::int32_t>> create_sub_index_map(
86 const IndexMap& imap, std::span<const std::int32_t> indices,
87 IndexMapOrder order = IndexMapOrder::any, bool allow_owner_change = false);
88
96{
97public:
106 IndexMap(MPI_Comm comm, std::int32_t local_size);
107
136 IndexMap(MPI_Comm comm, std::int32_t local_size,
137 std::span<const std::int64_t> ghosts, std::span<const int> owners,
138 int tag = static_cast<int>(dolfinx::MPI::tag::consensus_nbx));
139
159 IndexMap(MPI_Comm comm, std::int32_t local_size,
160 const std::array<std::vector<int>, 2>& src_dest,
161 std::span<const std::int64_t> ghosts, std::span<const int> owners);
162
163 // Copy constructor
164 IndexMap(const IndexMap& map) = delete;
165
167 IndexMap(IndexMap&& map) = default;
168
170 ~IndexMap() = default;
171
173 IndexMap& operator=(IndexMap&& map) = default;
174
175 // Copy assignment
176 IndexMap& operator=(const IndexMap& map) = delete;
177
179 std::array<std::int64_t, 2> local_range() const noexcept;
180
182 std::int32_t num_ghosts() const noexcept;
183
185 std::int32_t size_local() const noexcept;
186
188 std::int64_t size_global() const noexcept;
189
192 std::span<const std::int64_t> ghosts() const noexcept;
193
196 MPI_Comm comm() const;
197
201 void local_to_global(std::span<const std::int32_t> local,
202 std::span<std::int64_t> global) const;
203
209 void global_to_local(std::span<const std::int64_t> global,
210 std::span<std::int32_t> local) const;
211
215 std::vector<std::int64_t> global_indices() const;
216
220 std::span<const int> owners() const { return _owners; }
221
235 int tag = static_cast<int>(dolfinx::MPI::tag::consensus_nbx)) const;
236
241 std::vector<std::int32_t> shared_indices() const;
242
249 std::span<const int> src() const noexcept;
250
258 std::span<const int> dest() const noexcept;
259
273 std::vector<std::int32_t> weights_src() const;
274
288 std::vector<std::int32_t> weights_dest() const;
289
309 std::array<std::vector<int>, 2> rank_type(int split_type) const;
310
311private:
312 // Range of indices (global) owned by this process
313 std::array<std::int64_t, 2> _local_range;
314
315 // Number indices across communicator
316 std::int64_t _size_global;
317
318 // MPI communicator that map is defined on
319 dolfinx::MPI::Comm _comm;
320
321 // Local-to-global map for ghost indices
322 std::vector<std::int64_t> _ghosts;
323
324 // Owning rank on _comm for the ith ghost index
325 std::vector<int> _owners;
326
327 // Set of ranks that own ghosts
328 std::vector<int> _src;
329
330 // Set of ranks ghost owned indices
331 std::vector<int> _dest;
332};
333
334} // namespace dolfinx::common
Definition IndexMap.h:96
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:220
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 vector of indices (local numbering, owned or ghost) and an index map,...
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