hpx/collectives/gather.hpp
hpx/collectives/gather.hpp#
Defined in header hpx/collectives/gather.hpp.
See Public API for a list of names and headers that are part of the public HPX API.
-
namespace hpx
Top level HPX namespace.
-
namespace collectives
Top level HPX namespace.
Functions
-
template<typename T>
hpx::future<std::vector<decay_t<T>>> gather_here(char const *basename, T &&result, num_sites_arg num_sites = num_sites_arg(), this_site_arg this_site = this_site_arg(), generation_arg generation = generation_arg())# Gather a set of values from different call sites
This function receives a set of values from all call sites operating on the given base name.
- Parameters
basename – The base name identifying the gather operation
result – The value to transmit to the central gather point from this call site.
num_sites – The number of participating sites (default: all localities).
this_site – The sequence number of this invocation (usually the locality id). This value is optional and defaults to whatever hpx::get_locality_id() returns.
generation – The generational counter identifying the sequence number of the gather operation performed on the given base name. This is optional and needs to be supplied only if the gather operation on the given base name has to be performed more than once. The generation number (if given) must be a positive number greater than zero.
- Returns
This function returns a future holding a vector with all gathered values. It will become ready once the gather operation has been completed.
-
template<typename T>
hpx::future<std::vector<decay_t<T>>> gather_here(communicator comm, T &&result, this_site_arg this_site = this_site_arg(), generation_arg generation = generation_arg())# Gather a set of values from different call sites
This function receives a set of values from all call sites operating on the given base name.
Gather a set of values from different call sites
This function receives a set of values from all call sites operating on the given base name.
Note
The generation values from corresponding gather_here and gather_there have to match.
Note
The generation values from corresponding gather_here and gather_there have to match.
- Parameters
comm – A communicator object returned from create_communicator
result – The value to transmit to the central gather point from this call site.
this_site – The sequence number of this invocation (usually the locality id). This value is optional and defaults to whatever hpx::get_locality_id() returns.
generation – The generational counter identifying the sequence number of the gather operation performed on the given base name. This is optional and needs to be supplied only if the gather operation on the given base name has to be performed more than once. The generation number (if given) must be a positive number greater than zero.
comm – A communicator object returned from create_communicator
result – The value to transmit to the central gather point from this call site.
generation – The generational counter identifying the sequence number of the gather operation performed on the given base name. This is optional and needs to be supplied only if the gather operation on the given base name has to be performed more than once. The generation number (if given) must be a positive number greater than zero.
this_site – The sequence number of this invocation (usually the locality id). This value is optional and defaults to whatever hpx::get_locality_id() returns.
- Returns
This function returns a future holding a vector with all gathered values. It will become ready once the gather operation has been completed.
- Returns
This function returns a future holding a vector with all gathered values. It will become ready once the gather operation has been completed.
-
template<typename T>
hpx::future<void> gather_there(char const *basename, T &&local_result, this_site_arg this_site = this_site_arg(), generation_arg generation = generation_arg(), root_site_arg root_site = root_site_arg())# Gather a given value at the given call site
This function transmits the value given by result to a central gather site (where the corresponding gather_here is executed)
- Parameters
basename – The base name identifying the gather operation
local_result – The value to transmit to the central gather point from this call site.
this_site – The sequence number of this invocation (usually the locality id). This value is optional and defaults to whatever hpx::get_locality_id() returns.
generation – The generational counter identifying the sequence number of the gather operation performed on the given base name. This is optional and needs to be supplied only if the gather operation on the given base name has to be performed more than once. The generation number (if given) must be a positive number greater than zero.
root_site – The sequence number of the central gather point (usually the locality id). This value is optional and defaults to 0.
- Returns
This function returns a future holding a vector with all gathered values. It will become ready once the gather operation has been completed.
-
template<typename T>
hpx::future<void> gather_there(communicator fid, T &&local_result, this_site_arg this_site = this_site_arg(), generation_arg generation = generation_arg())# Gather a given value at the given call site
This function transmits the value given by result to a central gather site (where the corresponding gather_here is executed)
Gather a given value at the given call site
This function transmits the value given by result to a central gather site (where the corresponding gather_here is executed)
Note
The generation values from corresponding gather_here and gather_there have to match.
Note
The generation values from corresponding gather_here and gather_there have to match.
- Parameters
fid – A communicator object returned from create_communicator
local_result – The value to transmit to the central gather point from this call site.
this_site – The sequence number of this invocation (usually the locality id). This value is optional and defaults to whatever hpx::get_locality_id() returns.
generation – The generational counter identifying the sequence number of the gather operation performed on the given base name. This is optional and needs to be supplied only if the gather operation on the given base name has to be performed more than once. The generation number (if given) must be a positive number greater than zero.
fid – A communicator object returned from create_communicator
local_result – The value to transmit to the central gather point from this call site.
generation – The generational counter identifying the sequence number of the gather operation performed on the given base name. This is optional and needs to be supplied only if the gather operation on the given base name has to be performed more than once. The generation number (if given) must be a positive number greater than zero.
this_site – The sequence number of this invocation (usually the locality id). This value is optional and defaults to whatever hpx::get_locality_id() returns.
- Returns
This function returns a future holding a vector with all gathered values. It will become ready once the gather operation has been completed.
- Returns
This function returns a future holding a vector with all gathered values. It will become ready once the gather operation has been completed.
-
template<typename T>
-
namespace collectives