名稱空間
變體
操作

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
契約
2D 圖形
 
 
 
定義於標頭檔案 <experimental/simd>
template< class T, class Abi >
int find_first_set( const simd_mask<T, Abi>& k );
(1) (並行技術規範 v2)
template< class T, class Abi >
int find_last_set( const simd_mask<T, Abi>& k );
(2) (並行技術規範 v2)
1) 返回最低索引 i,其中 k[i]true
2) 返回最高索引 i,其中 k[i]true

如果 any_of(k)false,則行為未定義。

[編輯] 引數

k - 要應用約簡的 simd_mask

[編輯] 返回值

一個 int,範圍在 [0simd_size_v<T, Abi>)

[編輯] 示例

#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