std::experimental:: find_first_set, std::experimental:: find_last_set
From cppreference.net
<
cpp
|
experimental
|
simd
|
헤더 파일에 정의됨
<experimental/simd>
|
||
|
template
<
class
T,
class
Abi
>
int find_first_set ( const simd_mask < T, Abi > & k ) ; |
(1) | (parallelism TS v2) |
|
template
<
class
T,
class
Abi
>
int find_last_set ( const simd_mask < T, Abi > & k ) ; |
(2) | (parallelism TS v2) |
1)
가장 낮은 인덱스
i
를 반환합니다. 여기서
k
[
i
]
가
true
인 경우입니다.
2)
i
인덱스 중
k
[
i
]
가
true
인 가장 큰 인덱스를 반환합니다.
동작은 다음 중 any_of ( k ) 가 false 인 경우 정의되지 않습니다.
매개변수
| k | - |
감소를 적용할
simd_mask
객체
|
반환값
범위
[
0
,
simd_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