向量化计算(vectorization),说的是一个事情:把多次for循环计算变成一次计算。
上图中,左侧为vectorization,右侧是寻常的For loop计算。将多次for循环计算变成一次计算完全仰仗于CPU的SIMD指令集,SIMD指令集可以在一条CPU指令上处理2,4,8或者更多份的数据。在Inter处理器上,这个称之为SSE以及后来的AVX,在Arm上,这个称之为NEON。
因此简单来说,向量化计算就是将一个loop(处理一个数组的时候每次处理1个数据共处理N次)转化为vectorization(处理一个数组的时候每次同时处理8个数据共处理N/8次)
引用:https://zhuanlan.zhihu.com/p/72953129