如何将 __m128 反转为整数

Posted

技术标签:

【中文标题】如何将 __m128 反转为整数【英文标题】:how invert __m128 into ints 【发布时间】:2012-12-27 07:37:28 【问题描述】:
float a[4] = 1,2,3,4, b[4] = 4,3,2,1;
uint32_t c[4];

int main() 

    __m128 pa = _mm_loadu_ps(a);

    __m128 pb = _mm_loadu_ps(b);
    __m128 pc = _mm_cmpgt_ps(pa, pb);
    _mm_storeu_ps((float*)c, pc);
    for (int i = 0;i  < 4; ++i) printf("%u\n", c[i]);
    return 0;

_mm_storeu_ps((float*)c, pc)的正确指令是什么? 这里,c是一个整数数组……我觉得这种方式不好,有更好的吗?

【问题讨论】:

【参考方案1】:

在SSE2中有两条指令可以将__m128float向量)转换为__m128iint32_t向量):_mm_cvtps_epi32(带舍入)和_mm_cvttps_epi32(带截断)。

__m128i vi = _mm_cvttps_epi32(pc);
_mm_storeu_si128((__m128i *)c, vi);

如果不能使用SSE2,则应将pc存入float数组后,将float数组转换为int数组。

float d[4];
_mm_storeu_ps(d, pc);
c[0] = (int)d[0]; c[1] = (int)d[1]; c[2] = (int)d[2]; c[3] = (int)d[3];

【讨论】:

以上是关于如何将 __m128 反转为整数的主要内容,如果未能解决你的问题,请参考以下文章

LeetCode刷题记录_反转整数

Leetcode_07整数反转

如何使用 SSE 将 _m128i 转换为无符号整数?

反转 __m512i 寄存器中的值

ACM_整数反转

如何从 16 x 8 位 __m128i 值中提取 32 x 4 位整数