Namespaces
Variants

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

From cppreference.net
Definido en el encabezado <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 es una especialización de la plantilla de clase simd , proporciona la constante miembro value igual a true . Para cualquier otro tipo, value es false .
2) Si T es una especialización de la plantilla de clase simd_mask , proporciona la constante miembro value igual a true . Para cualquier otro tipo, value es false .

Contenidos

Parámetros de plantilla

T - un tipo a verificar

Plantilla de variable auxiliar

template < class T >
constexpr bool is_simd_v = is_simd < T > :: value ;
(parallelism TS v2)
template < class T >
constexpr bool is_simd_mask_v = is_simd_mask < T > :: value ;
(parallelism TS v2)

Heredado de std:: integral_constant

Constantes miembro

value
[static]
true si T es un tipo simd / simd_mask , false en caso contrario
(constante miembro pública estática)

Funciones miembro

operator bool
convierte el objeto a bool , devuelve value
(función miembro pública)
operator()
(C++14)
devuelve value
(función miembro pública)

Tipos miembro

Tipo Definición
value_type bool
type std:: integral_constant < bool , value >

Notas

is_simd_v < T > es necesario pero no suficiente para probar si T puede usarse como tipo SIMD. Por ejemplo, is_simd_v < simd < bool >> es true , a pesar de que bool no está incluido en los tipos vectorizables permitidos. La condición faltante es std:: is_constructible_v < T > , que es false para simd < bool > .

Ejemplo

#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>");
}

Salida:

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