如何使用整数除法 SSE 指令?
How do I use integer division SSE instructions?
根据参考here
以下函数应定义在 "immintrin.h"
__m128i _mm_idiv_epi32 (__m128i a, __m128i b);
__m128i _mm_idivrem_epi32 (__m128i * mem_addr, __m128i a, __m128i b);
__m128i _mm_set_epi32 (int e3, int e2, int e1, int e0);
但是根据我的测试程序,它们不是:
#include "immintrin.h"
int main() {
__m128i a = _mm_set_epi32(4,3,2,1);
__m128i b = _mm_set_epi32(1,2,3,4);
__m128i c = _mm_idiv_epi32(a,b);
__m128i d;
c = _mm_idivrem_epi32(&d, a, b);
}
编译失败,出现以下错误消息:
cc -g scratch.c && ./a.out
scratch.c: In function 'main':
scratch.c:11:15: warning: implicit declaration of function '_mm_idiv_epi32'; did you mean '_mm_rorv_epi32'? [-Wimplicit-function-declaration]
__m128i c = _mm_idiv_epi32(a,b);
^~~~~~~~~~~~~~
_mm_rorv_epi32
scratch.c:11:15: error: incompatible types when initializing type '__m128i {aka __vector(2) long long int}' using type 'int'
scratch.c:14:7: warning: implicit declaration of function '_mm_idivrem_epi32'; did you mean '_mm_movm_epi32'? [-Wimplicit-function-declaration]
c = _mm_idivrem_epi32(&d, a, b);
^~~~~~~~~~~~~~~~~
_mm_movm_epi32
scratch.c:14:5: error: incompatible types when assigning to type '__m128i {aka __vector(2) long long int}' from type 'int'
c = _mm_idivrem_epi32(&d, a, b);
显然这些函数根本没有定义。那我做错了什么?我错过了什么吗?
您的代码可以在最新版本的英特尔 ICC 编译器上正常编译。
函数 _mm_idiv_epi32
是一条 SVML 指令。 SVML 库与英特尔 ICC 编译器捆绑在一起。如果您无权访问或不能使用 ICC,获得可链接 SVML 的一种方法可能是安装并链接到 OpenCL。
根据参考here 以下函数应定义在 "immintrin.h"
__m128i _mm_idiv_epi32 (__m128i a, __m128i b);
__m128i _mm_idivrem_epi32 (__m128i * mem_addr, __m128i a, __m128i b);
__m128i _mm_set_epi32 (int e3, int e2, int e1, int e0);
但是根据我的测试程序,它们不是:
#include "immintrin.h"
int main() {
__m128i a = _mm_set_epi32(4,3,2,1);
__m128i b = _mm_set_epi32(1,2,3,4);
__m128i c = _mm_idiv_epi32(a,b);
__m128i d;
c = _mm_idivrem_epi32(&d, a, b);
}
编译失败,出现以下错误消息:
cc -g scratch.c && ./a.out
scratch.c: In function 'main':
scratch.c:11:15: warning: implicit declaration of function '_mm_idiv_epi32'; did you mean '_mm_rorv_epi32'? [-Wimplicit-function-declaration]
__m128i c = _mm_idiv_epi32(a,b);
^~~~~~~~~~~~~~
_mm_rorv_epi32
scratch.c:11:15: error: incompatible types when initializing type '__m128i {aka __vector(2) long long int}' using type 'int'
scratch.c:14:7: warning: implicit declaration of function '_mm_idivrem_epi32'; did you mean '_mm_movm_epi32'? [-Wimplicit-function-declaration]
c = _mm_idivrem_epi32(&d, a, b);
^~~~~~~~~~~~~~~~~
_mm_movm_epi32
scratch.c:14:5: error: incompatible types when assigning to type '__m128i {aka __vector(2) long long int}' from type 'int'
c = _mm_idivrem_epi32(&d, a, b);
显然这些函数根本没有定义。那我做错了什么?我错过了什么吗?
您的代码可以在最新版本的英特尔 ICC 编译器上正常编译。
函数 _mm_idiv_epi32
是一条 SVML 指令。 SVML 库与英特尔 ICC 编译器捆绑在一起。如果您无权访问或不能使用 ICC,获得可链接 SVML 的一种方法可能是安装并链接到 OpenCL。