自动矢量化技术,是编译器代码优化技术的一种,即在不改变C/C++源代码的情况下,自动编译产生使用单指令多数据(Single Instruction Multiple Data,SIMD)指令集的二进制码,包括MMX,SSE,SSE2,SSE3,SSSE3,SSE4,AVX,而不是程序员手动编写汇编层次的优化代码。
举例如下:
float a[N], b[N], c[N];
for(int i=0; i<N; ++i)
c[i] = a[i] + b[i];
上述代码中,逐项相加,并且a,b,c三个数据间是相互独立的,因而编译器可以对其进行矢量化优化,比如对于SSE指令集,XMM 128位寄存器,一次可以执行4个浮点运算,即
float a[N], b[N], c[N];
int i;
for(i=0; i<N-4; i+=4)
{
__asm
{
movups xmm0, a[i];
addps xmm0, b[i];
movups c[i], xmm0;
}
}
for(; i<N; ++i)
c[i] = a[i] + b[i];
当N较大时,如大于100,矢量优化后的执行速度提升是明显的。