std::experimental:: is_simd, std::experimental:: is_simd_mask
|
Défini dans l'en-tête
<experimental/simd>
|
||
|
template
<
class
T
>
struct is_simd ; |
(1) | (parallelism TS v2) |
|
template
<
class
T
>
struct is_simd_mask ; |
(2) | (parallelism TS v2) |
T
est une spécialisation du modèle de classe
simd
, fournit la constante membre
value
égale à
true
. Pour tout autre type,
value
est
false
.
T
est une spécialisation du modèle de classe
simd_mask
, fournit la constante membre
value
égale à
true
. Pour tout autre type,
value
est
false
.
Table des matières |
Paramètres du modèle
| T | - | un type à vérifier |
Modèle de variable d'assistance
|
template
<
class
T
>
constexpr bool is_simd_v = is_simd < T > :: value ; |
(parallelisme TS v2) | |
|
template
<
class
T
>
constexpr bool is_simd_mask_v = is_simd_mask < T > :: value ; |
(parallelisme TS v2) | |
Hérité de std:: integral_constant
Constantes membres
|
value
[static]
|
true
si
T
est un type
simd
/
simd_mask
,
false
sinon
(constante membre publique statique) |
Fonctions membres
|
operator bool
|
convertit l'objet en
bool
, retourne
value
(fonction membre publique) |
|
operator()
(C++14)
|
retourne
value
(fonction membre publique) |
Types membres
| Type | Définition |
value_type
|
bool |
type
|
std:: integral_constant < bool , value > |
Notes
is_simd_v
<
T
>
est nécessaire mais pas suffisant pour tester si
T
peut être utilisé comme type SIMD. Par exemple,
is_simd_v
<
simd
<
bool
>>
est
true
, même si
bool
n'est pas inclus dans les types vectorisables autorisés. La condition manquante est
std::
is_constructible_v
<
T
>
, qui est
false
pour
simd
<
bool
>
.
Exemple
#include <experimental/simd> #include <iostream> #include <string_view> namespace stdx = std::experimental; template<typename T> void test_simd(std::string_view type_name) { std::cout << std::boolalpha << "Type: " << type_name << '\n' << " is_simd: " << stdx::is_simd_v<T> << '\n' << " is_constructible: " << std::is_constructible_v<T> << '\n'; } template<typename T> void test_simd_mask(std::string_view type_name) { std::cout << std::boolalpha << "Type: " << type_name << '\n' << " is_simd_mask: " << stdx::is_simd_mask_v<T> << '\n' << " is_constructible: " << std::is_constructible_v<T> << "\n\n"; } int main() { test_simd<int>("int"); test_simd_mask<int>("int"); test_simd<stdx::simd<float>>("simd<float>"); test_simd_mask<stdx::simd_mask<float>>("simd_mask<float>"); test_simd<stdx::simd<bool>>("simd<bool>"); test_simd_mask<stdx::simd_mask<bool>>("simd_mask<bool>"); }
Sortie :
Type: int is_simd: false is_constructible: true Type: int is_simd_mask: false is_constructible: true Type: simd<float> is_simd: true is_constructible: true Type: simd_mask<float> is_simd_mask: true is_constructible: true Type: simd<bool> is_simd: true is_constructible: false Type: simd_mask<bool> is_simd_mask: true is_constructible: false