std::experimental::all_of, std::experimental::any_of, std::experimental::none_of, std::experimental::some_of
Von cppreference.com
< cpp | experimental | simd
| Definiert in Header <experimental/simd> |
||
| template< class T, class Abi > bool all_of( const simd_mask<T, Abi>& k ); |
(1) | (Parallelismus TS v2) |
| template< class T, class Abi > bool any_of( const simd_mask<T, Abi>& k ); |
(2) | (Parallelismus TS v2) |
| template< class T, class Abi > bool none_of( const simd_mask<T, Abi>& k ); |
(3) | (Parallelismus TS v2) |
| template< class T, class Abi > bool some_of( const simd_mask<T, Abi>& k ); |
(4) | (Parallelismus 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.
[edit] Parameter
| k | - | die simd_mask, auf die die Reduktion angewendet wird |
[edit] Rückgabewert
Das boolesche Ergebnis der horizontalen Reduktion.
[edit] Beispiel
Führen Sie diesen Code aus
#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 ); }