Namespaces
Variants

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

From cppreference.net
헤더 파일에 정의됨 <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