命名空间
变体
操作

std::experimental::find_first_set, std::experimental::find_last_set

来自 cppreference.com
< cpp‎ | experimental‎ | simd
 
 
实验性
技术规范
文件系统库 (文件系统 TS)
库基础 (库基础 TS)
库基础 2 (库基础 TS v2)
库基础 3 (库基础 TS v3)
并行扩展 (并行 TS)
并行扩展 2 (并行 TS v2)
并发扩展 (并发 TS)
并发扩展 2 (并发 TS v2)
概念 (概念 TS)
范围 (范围 TS)
反射 (反射 TS)
数学特殊函数 (特殊函数 TR)
实验性 非 TS
模式匹配
线性代数
std::execution
契约
二维图形
 
 
 
定义在头文件 <experimental/simd>
template< class T, class Abi >
int find_first_set( const simd_mask<T, Abi>& k );
(1) (并行 TS v2)
template< class T, class Abi >
int find_last_set( const simd_mask<T, Abi>& k );
(2) (并行 TS v2)
1) 返回最低索引 i,其中 k[i]true.
2) 返回最高索引 i,其中 k[i]true.

如果 any_of(k)false,则行为未定义。

[编辑] 参数

k - 要应用归约的 simd_mask

[编辑] 返回值

范围为 [0simd_size_v<T, Abi>)int

[编辑] 示例

#include <cstddef>
#include <experimental/simd>
#include <iostream>
 
namespace stdx = std::experimental;
 
template<typename Abi>
int find(stdx::simd_mask<Abi> const& v)
{
    if (stdx::any_of(v))
        return find_first_set(v);
    return -1;
}
 
int main()
{
    stdx::simd_mask<short> a{0};
    a[2] = a[a.size() - 2] = 1;
 
    for (std::size_t i = 0; i < a.size(); ++i)
        std::cout << a[i] << ' ';
    std::cout << '\n';
 
    std::cout << "find_first_set: " << stdx::find_first_set(a) << '\n';
    std::cout << "find_last_set: " << stdx::find_last_set(a) << '\n';
    std::cout << "find: " << find(a) << '\n';
    a[2] = 0;
    std::cout << "find: " << find(a) << '\n';
    a[a.size() - 2] = 0;
    std::cout << "find: " << find(a) << '\n';
}

可能的输出

0 0 1 0 0 0 1 0 
find_first_set: 2
find_last_set: 6
find: 2
find: 6
find: -1