objective-c - 如何在 C/Objective C 中使用 SSE 指令集?

标签 objective-c c sse

我正在尝试制作一个对 2 个 CGVectors 求和的函数。

这是我的尝试:

包括:

@import GLKit;
@import Foundations;


    // Defenition of CGVector
    struct CGVector {
        CGFloat dx;
        CGFloat dy;
    };

    typedef struct CGVector CGVector;

    inline CGVector CGVECADD(CGVector v1 , CGVector v2){
    #ifdef GLK_SSE3_INTRINSICS
        __m128d v;
        v = _mm_add_sd(*(__m128d *)&v1, *(__m128d *)&v2);

        return *(CGVector *)& v;
    #else
        return CGVectorMake(v1.dx + v2.dx, v1.dy + v2.dy);
    #endif
    }

然后我试着像这样使用它

    CGVector v1, v2 , v3;
    v1 = CGVectorMake(2, 3);
    v2 = CGVectorMake(4, 4);;
    v3 = CGVECADD(v1, v2); //(6, 7) expected
    NSLog(@"V3 = (%lf, %lf)", v3.dx , v3.dy);

没有编译器错误但是我从日志中得到的是

V3 = (6.000000, 3.000000)

我希望有 6,7 :-)

我做错了什么?

最佳答案

你应该能够做到:

CGVector v1, v2, v3;
v1 = CGVectorMake(2, 3);
v2 = CGVectorMake(4, 4);
v3 = CGVectorMake(v1.dx + v2.dx, v1.dy + v2.dy);
NSLog(@"V3 = (%f, %f)", v3.dx, v3.dy);

输出:

V3 = (6.000000, 7.000000)

关于objective-c - 如何在 C/Objective C 中使用 SSE 指令集?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39811507/

相关文章:

arm - 平均操作 ARM NEON

c++ - 紧凑型 AVX2 寄存器,因此所选整数根据掩码是连续的

caching - 如何正确使用预取指令?

objective-c - AVAssetReader/Writer 只适用于某些设备?

javascript - 在 UIWebView 的 div 中找到光标位置的 y 坐标

c - 父进程如何找到导致其子进程死亡的进程的pid?

c - gdb运行程序问题

ios - 使用 objc 的 swift 扩展和类型差异

Objective-C 类别

c - 在 else 语句中返回有好处/坏处吗?