ARM Neon iOS浮点转换

时间:2014-10-17 14:18:37

标签: ios arm neon

当我在iPad Air(iOS 7.1)

上执行此代码时
#include <arm_neon.h>

static inline void TestArmConversion()
{
    float x[2] = { 1.5, 2.6 };
    int32_t z[2];

    vst1_s32(z, vcvt_f32_s32(vld1_f32(x)));

    for (int k = 0; k < 2; k++)
    {
        printf("z[%d] = %d\n", k, z[k]);
    }
}

...我得到以下结果:

z[0] = 1316945920
z[1] = 1317031117

我原本希望得到

z [0] = 1    z [1] = 2

我做错了什么?

1 个答案:

答案 0 :(得分:3)

你很亲密!你只是混淆了转换。请改用vcvt_s32_f32(float32x2_t)