命名空间
变体
操作

std::experimental::reduce、 std::experimental::hmin、 std::experimental::hmax

来自 cppreference.cn
< cpp‎ | experimental‎ | simd
 
 
实验性
技术规范
文件系统库 (filesystem TS)
库基础 (library fundamentals TS)
库基础 2 (library fundamentals TS v2)
库基础 3 (library fundamentals TS v3)
并行性扩展 (parallelism TS)
并行性扩展 2 (parallelism TS v2)
并发性扩展 (concurrency TS)
并发性扩展 2 (concurrency TS v2)
概念 (concepts TS)
范围 (ranges TS)
反射 (reflection TS)
数学特殊函数 (special functions TR)
实验性非TS
模式匹配
线性代数
std::execution
契约
2D图形
 
 
 
定义于头文件 <experimental/simd>
template< class T, class Abi, class BinaryOperation = std::plus<> >
T reduce( const simd<T, Abi>& v, BinaryOperation binary_op = {} );
(1) (并行性 TS v2)
template< class M, class V, class BinaryOperation >

typename V::value_type
reduce( const const_where_expression<M, V>& x,

        typename V::value_type identity_element, BinaryOperation binary_op = {} );
(2) (并行性 TS v2)
template< class M, class V >

typename V::value_type

reduce( const const_where_expression<M, V>& x, std::plus<> binary_op ) noexcept;
(3) (并行性 TS v2)
template< class M, class V >

typename V::value_type

reduce( const const_where_expression<M, V>& x, std::multiplies<> binary_op ) noexcept;
(4) (并行性 TS v2)
template< class M, class V >

typename V::value_type

reduce( const const_where_expression<M, V>& x, std::bit_and<> binary_op ) noexcept;
(5) (并行性 TS v2)
template< class M, class V >

typename V::value_type

reduce( const const_where_expression<M, V>& x, std::bit_or<> binary_op ) noexcept;
(6) (并行性 TS v2)
template< class M, class V >

typename V::value_type

reduce( const const_where_expression<M, V>& x, std::bit_xor<> binary_op ) noexcept;
(7) (并行性 TS v2)
template< class T, class Abi >
T hmin( const simd<T, Abi>& v ) noexcept;
(8) (并行性 TS v2)
template< class M, class V >

typename V::value_type

hmin( const const_where_expression<M, V>& x ) noexcept;
(9) (并行性 TS v2)
template< class T, class Abi >
T hmax( const simd<T, Abi>& v ) noexcept;
(10) (并行性 TS v2)
template< class M, class V >

typename V::value_type

hmax( const const_where_expression<M, V>& x ) noexcept;
(11) (并行性 TS v2)
1)v 上对所有值进行 binary_op 归约。
2)x 中关联掩码元素为 true 的值上进行 binary_op 归约。
3) 返回 x 中关联掩码元素为 true 的所有值的总和。
4) 返回 x 中关联掩码元素为 true 的所有值的乘积。
5) 返回 x 中关联掩码元素为 true 的所有值使用按位与的聚合结果。
6) 返回 x 中关联掩码元素为 true 的所有值使用按位或的聚合结果。
7) 返回 x 中关联掩码元素为 true 的所有值使用按位异或的聚合结果。
8)v 上对所有值进行 std::min 归约。
9)x 中关联掩码元素为 true 的值上进行 std::min 归约。
10)v 上对所有值进行 std::max 归约。
11)x 中关联掩码元素为 true 的值上进行 std::max 归约。

如果 binary_op 不是结合律或交换律,则行为是不确定的。

目录

[edit] 参数

v - 应用归约的 simd 向量
x - 要应用归约的 where 表达式的返回值
identity_element - 充当 binary_op 的单位元素的值;对于类型为 V::value_type 的所有有限 a,必须满足 binary_op(identity_element, a) == a
binary_op - 将在未指定的顺序应用于类型为 V::value_typesimd<V::value_type, A> 的参数的二元 FunctionObject,带有未指定的 ABI 标签 Abinary_op(v, v) 必须可转换为 V

[edit] 返回值

类型操作的结果

1,8,10) T
2-7,9,11) V::value_type

[edit] 示例

#include <array>
#include <cassert>
#include <cstddef>
#include <experimental/simd>
#include <functional>
#include <iostream>
#include <numeric>
namespace stdx = std::experimental;
 
int main()
{
    using V = stdx::native_simd<double>;
 
    alignas(stdx::memory_alignment_v<V>) std::array<V::value_type, 1024> data;
    std::iota(data.begin(), data.end(), 0);
 
    V::value_type acc{};
    for (std::size_t i = 0; i < data.size(); i += V::size())
        acc += stdx::reduce(V(&data[i], stdx::vector_aligned), std::plus{});
    std::cout << "sum of data = " << acc << '\n';
 
    using W = stdx::fixed_size_simd<int, 4>;
    alignas(stdx::memory_alignment_v<W>) std::array<int, 4> arr{2, 5, 4, 1};
    auto w = W(&arr[0], stdx::vector_aligned);
    assert(stdx::hmin(w) == 1 and stdx::hmax(w) == 5);
}

输出

sum of data = 523776

[edit] 参见

(C++17)
类似于 std::accumulate,但顺序不定
(函数模板) [编辑]