将8个16位SSE寄存器转换为8位数据

Nav*_*ath 3 x86 sse intel simd

考虑我有一个包含16位数据的SSE数组:

{1,2,3,4,5,6,7,8}

现在我需要通过在前8个字节中仅存储16位数据的低字节来将此SSE数组转换为8位数据,如:

{1,2,3,4,5,6,7,8,0,0,0,0,0,0,0,0}.

是否有任何SSE指令来执行此操作?

Pau*_*l R 5

正如@harold在上面的评论中所说,你可以很容易地使用pshufbaka_mm_shuffle_epi8,例如

#include <stdio.h>
#include <tmmintrin.h>

static __m128i pack_16_to_8(const __m128i v)
{
    const __m128i vperm = _mm_setr_epi8(0, 2, 4, 6, 8, 10, 12, 14, -1, -1, -1, -1, -1, -1, -1, -1);

    return _mm_shuffle_epi8(v, vperm);
}

int main(void)
{
    const __m128i v = _mm_setr_epi16(1, 2, 3, 4, 5, 6, 7, 8);

    printf("%vhd -> %vd\n", v, pack_16_to_8(v));
    return 0;
}
Run Code Online (Sandbox Code Playgroud)

编译并运行:

$ gcc -Wall -mssse3 pack_16_to_8.c && ./a.out

1 2 3 4 5 6 7 8 -> 1 2 3 4 5 6 7 8 0 0 0 0 0 0 0 0
Run Code Online (Sandbox Code Playgroud)