Namespaces
Variants

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

From cppreference.net
Definiert im Header <experimental/simd>
template < class T >
struct is_simd ;
(1) (Parallelism TS v2)
template < class T >
struct is_simd_mask ;
(2) (Parallelism TS v2)
1) Falls T eine Spezialisierung der simd -Klassentemplate ist, stellt die Memberkonstante value gleich true bereit. Für jeden anderen Typ ist value gleich false .
2) Falls T eine Spezialisierung der simd_mask Klassenvorlage ist, stellt die Memberkonstante value gleich true bereit. Für jeden anderen Typ ist value gleich false .

Inhaltsverzeichnis

Template-Parameter

T - ein zu prüfender Typ

Hilfsvariablen-Template

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)
*Hinweis: Der Text innerhalb der ` ` Tags (C++ Code) wurde gemäß den Anforderungen nicht übersetzt. Die einzige übersetzte Textstelle war "(parallelism TS v2)", das zu "(Parallelism TS v2)" wurde, wobei "TS" als technischer Begriff unverändert blieb.*

Geerbt von std:: integral_constant

Member-Konstanten

value
[static]
true falls T ein simd / simd_mask -Typ ist, false andernfalls
(öffentliche statische Member-Konstante)

Member-Funktionen

operator bool
konvertiert das Objekt zu bool , gibt value zurück
(öffentliche Member-Funktion)
operator()
(C++14)
gibt value zurück
(öffentliche Member-Funktion)

Member-Typen

Typ Definition
value_type bool
type std:: integral_constant < bool , value >

Hinweise

is_simd_v < T > ist notwendig, aber nicht ausreichend, um zu testen, ob T als SIMD-Typ verwendet werden kann. Zum Beispiel ist is_simd_v < simd < bool >> true , obwohl bool nicht in den zulässigen vektorisierbaren Typen enthalten ist. Die fehlende Bedingung ist std:: is_constructible_v < T > , was für simd < bool > false ist.

Beispiel

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

Ausgabe:

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