|
Ginkgo
Generated from pipelines/1330831941 branch based on master. Ginkgo version 1.8.0
A numerical linear algebra library targeting many-core architectures
|
5 #ifndef GKO_PUBLIC_CORE_DISTRIBUTED_PARTITION_HPP_
6 #define GKO_PUBLIC_CORE_DISTRIBUTED_PARTITION_HPP_
9 #include <ginkgo/core/base/array.hpp>
10 #include <ginkgo/core/base/polymorphic_object.hpp>
11 #include <ginkgo/core/base/types.hpp>
15 namespace experimental {
21 namespace distributed {
78 template <
typename LocalIndexType =
int32,
typename GlobalIndexType =
int64>
79 class Partition :
public EnablePolymorphicObject<
80 Partition<LocalIndexType, GlobalIndexType>>,
81 public EnablePolymorphicAssignment<
82 Partition<LocalIndexType, GlobalIndexType>> {
83 friend class EnablePolymorphicObject<Partition>;
84 static_assert(
sizeof(GlobalIndexType) >=
sizeof(LocalIndexType),
85 "GlobalIndexType must be at least as large as "
92 using local_index_type = LocalIndexType;
93 using global_index_type = GlobalIndexType;
127 return num_empty_parts_;
219 std::shared_ptr<const Executor> exec,
236 std::shared_ptr<const Executor> exec,
253 global_index_type global_size);
256 Partition(std::shared_ptr<const Executor> exec,
259 static std::unique_ptr<Partition> create(
268 void finalize_construction();
272 global_index_type size_;
285 #endif // GKO_PUBLIC_CORE_DISTRIBUTED_PARTITION_HPP_
static std::unique_ptr< Partition > build_from_global_size_uniform(std::shared_ptr< const Executor > exec, comm_index_type num_parts, global_index_type global_size)
Builds a partition by evenly distributing the global range.
void move_to(result_type *result) override
Converts the implementer to an object of type result_type by moving data from this object.
Definition: polymorphic_object.hpp:732
void convert_to(result_type *result) const override
Converts the implementer to an object of type result_type.
Definition: polymorphic_object.hpp:730
local_index_type get_part_size(comm_index_type part) const
Returns the size of a part given by its part ID.
const local_index_type * get_part_sizes() const noexcept
Returns the part size array.
Definition: partition.hpp:178
std::size_t size_type
Integral type used for allocation quantities.
Definition: types.hpp:108
const local_index_type * get_range_starting_indices() const noexcept
Returns the part-local starting index for each range in this partition.
Definition: partition.hpp:167
static std::unique_ptr< Partition > build_from_contiguous(std::shared_ptr< const Executor > exec, const array< global_index_type > &ranges, const array< comm_index_type > &part_ids={})
Builds a partition consisting of contiguous ranges, one for each part.
const global_index_type * get_range_bounds() const noexcept
Returns the ranges boundary array stored by this partition.
Definition: partition.hpp:137
The Ginkgo namespace.
Definition: abstract_factory.hpp:20
comm_index_type get_num_parts() const noexcept
Returns the number of parts represented in this partition.
Definition: partition.hpp:118
bool has_ordered_parts() const
Checks if the ranges are ordered by their part index.
const comm_index_type * get_part_ids() const noexcept
Returns the part IDs of the ranges in this partition.
Definition: partition.hpp:149
size_type get_size() const
Returns the total number of elements represented by this partition.
Definition: partition.hpp:100
comm_index_type get_num_empty_parts() const noexcept
Returns the number of empty parts within this partition.
Definition: partition.hpp:125
bool has_connected_parts() const
Checks if each part has no more than one contiguous range.
const value_type * get_const_data() const noexcept
Returns a constant pointer to the block of memory used to store the elements of the array.
Definition: array.hpp:683
size_type get_num_ranges() const noexcept
Returns the number of ranges stored by this partition.
Definition: partition.hpp:108
size_type get_size() const noexcept
Returns the number of elements in the array.
Definition: array.hpp:657
static std::unique_ptr< Partition > build_from_mapping(std::shared_ptr< const Executor > exec, const array< comm_index_type > &mapping, comm_index_type num_parts)
Builds a partition from a given mapping global_index -> part_id.
int comm_index_type
Index type for enumerating processes in a distributed application.
Definition: types.hpp:806