编译程序(test.cpp)时出现以下错误:
> g++ -o test test.cpp -O2 -mavx -msse4.1
test.cpp: In function ‘int main(int, char**)’:
test.cpp:18:42: error: ‘_mm_rorv_epi32’ was not declared in this scope
indice = _mm_rorv_epi32(indice, offset4);
^
程序(main.cpp):
#include <stdio.h>
#include <stdlib.h>
#include <immintrin.h>
int main(int argc, char* argv[]) {
float values[4] = {1., 2., 3., 4.};
__m128i offset4 = _mm_set_epi32(0, 2, 4, 6);
__m128i mask4 = _mm_set_epi32(3, 3, 3, 3);
__m128 value4 = _mm_load_ps(&values[0]);
__m128 res;
float result[4];
// load a constant integer 4 times
__m128i indice = _mm_set1_epi32(123); // 123 is a fake example
// shift
indice = _mm_rorv_epi32(indice, offset4);
// and
indice = _mm_and_si128(indice, mask4);
// lookup
res = _mm_permutevar_ps(value4, indice);
// store
_mm_store_ps(result, res);
for (int i = 0; i < 4; i++) {
printf("result[%d] = %g\n", i, result[i]);
}
return 0;
}
我确实根据英特尔手册包含了头文件immintrin.h
。 g++
版本是 4.9.3
。
如何解决编译问题并使用_mm_rorv_epi32
?
最佳答案
_mm_rorv_epi32
根据Intel page在 _mm_rorv_epi32
上,此内在函数需要 avx512f
和 avx512vl
。您需要使用 -mavx512vl
进行编译才能启用它(并且您的 gcc 太旧 - -mavx512vl
是 added in gcc-5.1 )。
关于g++ - 无法使用AVX512编译C++程序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41436163/