...one of the most highly
regarded and expertly designed C++ library projects in the
world.
— Herb Sutter and Andrei
Alexandrescu, C++
Coding Standards
boost::compute::reduce_by_key
// In header: <boost/compute/algorithm/reduce_by_key.hpp> template<typename InputKeyIterator, typename InputValueIterator, typename OutputKeyIterator, typename OutputValueIterator, typename BinaryFunction, typename BinaryPredicate> std::pair< OutputKeyIterator, OutputValueIterator > reduce_by_key(InputKeyIterator keys_first, InputKeyIterator keys_last, InputValueIterator values_first, OutputKeyIterator keys_result, OutputValueIterator values_result, BinaryFunction function, BinaryPredicate predicate, command_queue & queue = system::default_queue()); template<typename InputKeyIterator, typename InputValueIterator, typename OutputKeyIterator, typename OutputValueIterator, typename BinaryFunction> std::pair< OutputKeyIterator, OutputValueIterator > reduce_by_key(InputKeyIterator keys_first, InputKeyIterator keys_last, InputValueIterator values_first, OutputKeyIterator keys_result, OutputValueIterator values_result, BinaryFunction function, command_queue & queue = system::default_queue()); template<typename InputKeyIterator, typename InputValueIterator, typename OutputKeyIterator, typename OutputValueIterator> std::pair< OutputKeyIterator, OutputValueIterator > reduce_by_key(InputKeyIterator keys_first, InputKeyIterator keys_last, InputValueIterator values_first, OutputKeyIterator keys_result, OutputValueIterator values_result, command_queue & queue = system::default_queue());
The reduce_by_key()
algorithm performs reduction for each contiguous subsequence of values determinate by equivalent keys.
Returns a pair of iterators at the end of the ranges [keys_result
, keys_result_last) and [values_result
, values_result_last
).
If no function is specified, plus
will be used. If no predicate is specified, equal_to
will be used.
The reduce_by_key()
algorithm assumes that the binary reduction function is associative. When used with non-associative functions the result may be non-deterministic and vary in precision. Notably this affects the plus<float>()
function as floating-point addition is not associative and may produce slightly different results than a serial algorithm.
For example, to calculate the sum of the values for each key:
Space complexity on GPUs: \Omega(2n)
Space complexity on CPUs: \Omega(1)
See Also:
reduce()
Parameters: |
|