std::experimental::simd_mask<T,Abi>:: simd_mask
From cppreference.net
<
cpp
|
experimental
|
simd
|
simd mask
|
simd_mask
(
)
noexcept
=
default
;
|
(1) | (parallelism TS v2) |
|
explicit
simd_mask
(
bool
value
)
noexcept
;
|
(2) | (parallelism TS v2) |
|
template
<
class
U
>
simd_mask ( const simd_mask < U, simd_abi :: fixed_size < size ( ) >> & other ) noexcept ; |
(3) | (parallelism TS v2) |
|
template
<
class
U,
class
Flags
>
simd_mask ( const bool * mem, Flags flags ) ; |
(4) | (parallelism TS v2) |
|
simd_mask
(
const
simd_mask
&
other
)
noexcept
=
default
;
|
(5) |
(parallelism TS v2)
(неявно объявлен) |
|
simd_mask
(
simd_mask
&&
other
)
noexcept
=
default
;
|
(6) |
(parallelism TS v2)
(неявно объявлен) |
1)
Создает
simd_mask
с использованием
инициализации по умолчанию
(создается без инициализатора) или
инициализации значением
(создается с пустым инициализатором).
2)
Конструктор вещания создает
simd_mask
со всеми значениями, инициализированными как
value
.
3)
Создает
simd_mask
, где i-й элемент инициализируется значением
other
[
i
]
для всех
i
в диапазоне
[
0
,
size()
)
. Эта перегрузка участвует в разрешении перегрузки только если
Abi
является
simd_abi
::
fixed_size
<
size
(
)
>
.
4)
Конструктор загрузки создает
simd_mask
, в котором i-й элемент инициализируется значением
mem
[
i
]
для всех
i
в диапазоне
[
0
,
size()
)
.
5,6)
Неявно объявленные конструкторы копирования и перемещения. Создают
simd_mask
, где каждый элемент инициализируется значениями элементов из
other
.
Параметры
| value | - |
значение, используемое для инициализации всех
simd_mask
элементов
|
| other | - |
другой
simd_mask
для копирования
|
| mem | - |
указатель на массив, где
[
mem
,
mem
+
size
(
)
)
является допустимым диапазоном
|
| flags | - |
если имеет тип
vector_aligned_tag
, конструктор загрузки может предполагать
mem
указывает на память, выровненную по
memory_alignment_v<simd_mask>
|
| Требования к типам | ||
-
is_simd_flag_type_v<Flags>
должно быть
true
.
|
||
Пример
Запустить этот код
#include <algorithm> #include <cstddef> #include <experimental/simd> #include <iostream> namespace stdx = std::experimental; int main() { [[maybe_unused]] stdx::native_simd_mask<int> a; // неинициализирован stdx::native_simd_mask<int> b(true); // все элементы инициализированы значением true stdx::native_simd_mask<int> c{}; // все элементы инициализированы значением false alignas(stdx::memory_alignment_v<stdx::native_simd_mask<int>>) std::array<bool, stdx::native_simd_mask<int>::size() * 2> mem = {}; std::ranges::generate(mem, [i{0}] mutable -> bool { return i++ & 1; }); stdx::native_simd_mask<int> d(&mem[0], stdx::vector_aligned); // {0, 1, 0, 1, ...} stdx::native_simd_mask<int> e(&mem[1], stdx::element_aligned); // {1, 0, 1, 0, ...} const auto xored = b ^ c ^ d ^ e; for (std::size_t i{}; i != xored.size(); ++i) std::cout << xored[i] << ' '; std::cout << '\n'; }
Возможный вывод:
0 0 0 0 0 0 0 0
Смотрите также
|
(parallelism TS v2)
|
флаг, указывающий выравнивание адреса загрузки/сохранения по выравниванию элемента
(класс) |
|
(parallelism TS v2)
|
флаг, указывающий выравнивание адреса загрузки/сохранения по выравниванию вектора
(класс) |
|
(parallelism TS v2)
|
флаг, указывающий выравнивание адреса загрузки/сохранения по указанному выравниванию
(шаблон класса) |
|
(parallelism TS v2)
|
получает подходящее выравнивание для
vector_aligned
(шаблон класса) |
|
(parallelism TS v2)
|
загружает элементы
simd_mask
из непрерывной памяти
(открытая функция-член) |