std::experimental:: all_of, std::experimental:: any_of, std::experimental:: none_of, std::experimental:: some_of
From cppreference.net
<
cpp
|
experimental
|
simd
|
Definiert im Header
<experimental/simd>
|
||
|
template
<
class
T,
class
Abi
>
bool all_of ( const simd_mask < T, Abi > & k ) ; |
(1) | (Parallelism TS v2) |
|
template
<
class
T,
class
Abi
>
bool any_of ( const simd_mask < T, Abi > & k ) ; |
(2) | (Parallelism TS v2) |
|
template
<
class
T,
class
Abi
>
bool none_of ( const simd_mask < T, Abi > & k ) ; |
(3) | (Parallelism TS v2) |
|
template
<
class
T,
class
Abi
>
bool some_of ( const simd_mask < T, Abi > & k ) ; |
(4) | (Parallelism TS v2) |
1)
Gibt
true
zurück, wenn alle Werte in
k
true
sind.
2)
Gibt
true
zurück, wenn mindestens ein Wert in
k
true
ist.
3)
Gibt
true
zurück, wenn alle Werte in
k
false
sind.
4)
Gibt
true
zurück, wenn mindestens ein Wert in
k
true
ist, aber nicht alle Werte in
k
true
sind.
Parameter
| k | - |
die
simd_mask
auf die die Reduktion angewendet werden soll
|
Rückgabewert
Das boolesche Ergebnis der horizontalen Reduktion.
Beispiel
Diesen Code ausführen
#include <cassert> #include <experimental/simd> namespace stq = std::experimental; int main() { using mask = stq::fixed_size_simd_mask<int, 4>; mask mask1{false}; // = {0, 0, 0, 0} assert ( stq::none_of(mask1) == true && stq::any_of(mask1) == false && stq::some_of(mask1) == false && stq::all_of(mask1) == false ); mask mask2{true}; // = {1, 1, 1, 1} assert ( stq::none_of(mask2) == false && stq::any_of(mask2) == true && stq::some_of(mask2) == false && stq::all_of(mask2) == true ); mask mask3{true}; mask3[0] = mask3[1] = false; // mask3 = {0, 0, 1, 1} assert ( stq::none_of(mask3) == false && stq::any_of(mask3) == true && stq::some_of(mask3) == true && stq::all_of(mask3) == false ); }