Побитовый сдвиг в AVX512C++

Программы на C++. Форум разработчиков
Ответить Пред. темаСлед. тема
Anonymous
 Побитовый сдвиг в AVX512

Сообщение Anonymous »

Я хочу использовать встроенные инструкции или инструкции ассемблера для сдвига 64 8-битных элементов на 1 позицию. Например, это (1, 2, 3,...., 63, 64) В этом (0, 1, 2, 3,...,62, 63) без потери элементов.
для 32 8-битных элементов и AVX, AVX2 можно сделать так:
src = (1,2,3,...,63, 64),
mask = ( 0, 0, ...,255,...,0,0) (нужно, так как мы потеряли 1 элемент),

Код: Выделить всё

a = _mm256_sli_si256(src, 1);
src = _mm256_and_si256(src, mask);
src = _mm256_permute2f128_si256(src, src, 1);
src = _mm256_srli_si256(src, 15);
src = _mm256_add_epi16(a, src);
в результате src = (0, 1, 2, 3,...,62,63)

Подробнее здесь: https://stackoverflow.com/questions/783 ... -in-avx512
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • Побитовый сдвиг выводит неверный результат
    Гость » » в форуме Python
    0 Ответы
    43 Просмотры
    Последнее сообщение Гость
  • Как реализовать логический побитовый сдвиг/поворот при пересечении полосы движения (влево и вправо) в AVX2
    Anonymous » » в форуме C++
    0 Ответы
    25 Просмотры
    Последнее сообщение Anonymous
  • Эквивалентная функция для _mm256_sign_epi8 в AVX512
    Anonymous » » в форуме C++
    0 Ответы
    18 Просмотры
    Последнее сообщение Anonymous
  • AVX512 выполняет И 512 бит 8-битных символов.
    Anonymous » » в форуме C++
    0 Ответы
    17 Просмотры
    Последнее сообщение Anonymous
  • Установка вектора AVX512 на ноль/ненулевое значение иногда приводит к появлению сигнала SIGILL на Godbolt.
    Anonymous » » в форуме C++
    0 Ответы
    24 Просмотры
    Последнее сообщение Anonymous

Вернуться в «C++»