std::experimental::find_first_set, std::experimental::find_last_set
來自 cppreference.com
< cpp | experimental | simd
定義於標頭檔案 <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,範圍在 [
0,
simd_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