c++ - 如何将 __m128 转换为整数

标签 c++ sse

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是一个整型数组……我觉得这样不好,有什么更好的吗?

最佳答案

在SSE2中有两条指令将__m128(float vector )转换为__m128i(int32_t vector ) : _mm_cvtps_epi32 (四舍五入)和_mm_cvttps_epi32 (有截断)。

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

如果不能使用SSE2,将pc存入floatfloat数组转为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];

关于c++ - 如何将 __m128 转换为整数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14051140/

相关文章:

c++ - 如何使用 OpenMP 等待互斥锁

c++ - 测试两个模板是否相同,即使使用非类型参数包作为参数

c++ - C++ 变量的定义,Basic/6 部分

c++ - sse 快速加载数组的前半部分

c++ - 使用(float&)int可以进行类型修剪,(float const&)int可以像(float)int那样转换吗?

intel - x86 兼容加速器 Intel Xeon Phi 中是否有 SIMD(SSE/AVX)指令?

c++ - 二叉树的删除函数出错? (C++)

c++ - 当在错误槽中启动事件循环时发生 ContentNotFoundError 时,QNetworkReply 会发出两次错误信号

c++ - 将浮点 vector 转换为 16 位 int 而不饱和

c++ - SSE4 _mm_cmpistrm 在字符串中查找字符(完整代码示例)