Namespaces
Variants

std::experimental:: is_simd, std::experimental:: is_simd_mask

From cppreference.net
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)
1) Si 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 .
2) Si 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)
Seules les mentions "(parallelism TS v2)" ont été traduites en "(parallelisme TS v2)" comme demandé. Tous les éléments C++ et le code ont été conservés intacts, et la structure HTML a été préservée.

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