梁德澎 · 2020年07月09日

EasyQuant 后量化算法论文解读

本文的主要内容是解读 EasyQuant: Post-training Quantization via Scale Optimization 这篇由格灵深瞳出品的文章。
授权转自知乎:EasyQuant 论文解读
作者:梁德澎

论文地址: https://arxiv.org/pdf/2006.16669.pdf
论文代码: https://github.com/deepglint/EasyQuant

前言

这篇文章提出的后训练量化算法的思路是,引入cos相似性作为目标函数,通过交替搜索权值和激活的量化因子(scale)来最大化量化前后激活值的 cos 相似性,来找到权值和激活值的最优量化因子。

而实际端上推理阶段则采用权值和激活 int7 量化,中间 int16 累加器累加多次的方式,使得推理速度优于权值和激活 int8 量化,中间 int16 累加器只累加两次的方式,同时还可以比较好的保持量化后算法的精度。

之前一些的量化方法算法的不足

TensorRT的后量化算法与谷歌提出的训练量化等方法,有个共同点是对于权值的量化,都是直接取绝对值最大作为量化因子,也就是image.png

每层激活量化因子的计算方式

TensorRT采用的方法是过两遍校验集,第一遍统计该层激活绝对值的最大值image.png ,第二遍先把区间image.png分为2048份然后统计直方图,统计完成之后搜索直方图[128,2048]的区间,通过计算KL散度的方式来确定最佳阈值从而得到量化因子,更详细的内容可以看参考资料[4,5]

而谷歌提出的训练量化方法则是,在训练中采用 EMA(exponential moving average) 的方式统计量化因子[6],具体公式是image.png

其中image.png表示当前batch的激活值,image.png一般取0.95,训练完成之后量化因子可以通过公式image.png获得。

该论文则指出这些方法主要的不足之处在于

  • 只优化激活的量化因子而权值直接取最大值做量化的话其实会造成误差积累的问题,所以权值的量化因子也要优化;
  • 在优化量化因子的时候,并没有考虑卷积层原始浮点输出与量化版本实现输出的分布的相似性。

论文算法解读

量化的定义

首先来看下量化的一般公式:

image.png

其中X表示需要量化的张量,S表示量化因子,image.png表示量化之后的张量, Round 操作论文里表示向上取整的意思,image.png表示elementwise点乘操作,Clip 而则表示饱和操作,比如量化到 int8,就是把量化后值限定在 [-128,127] 之间,超出的值取边界值。

image.png

优化目标

量化推理的流程图

https://arxiv.org/pdf/2006.16669.pdf

首先看下论文里的这张图片,展示了第l层卷积层量化推理的流程图。

https://arxiv.org/pdf/2006.16669.pdf

首先看最左边的方框,权值和激活从float32量化到int8,权值因为可以分通道量化,所以可以看到权值的量化因子是分了3种不同颜色的立方体分别对应了权值3个不同颜色的通道。

https://arxiv.org/pdf/2006.16669.pdf

然后中间的方框,表示推理阶段量化版本卷积的实现,可以看到有根据kernel设置分别优化,还有具体实现上用 im2col+gemm 或者 Winograd 优化实现等等

https://arxiv.org/pdf/2006.16669.pdf

最后看最右边的方框,表示得到卷积层输出量化激活结果之后,如果下一层不是量化计算层,则直接除以权值和输入激活的量化因子,得到反量化的输出(Dequantize)。如果下一层也是量化层,则除了除以权值和输入激活的量化因子还需要再乘以下一层的输入量化因子得到量化后的下一层的输入(Requantize)。

优化单层量化因子

接着看下论文提出的优化目标函数:

image.png

https://github.com/deepglint/EasyQuant/blob/f2f2e6cf38/tools/caffe_quanttable_e2e.py#L428

image.png
https://github.com/deepglint/EasyQuant/blob/f2f2e6cf38/tools/scale\_fine\_tuning.py#L351

然后对于激活的量化因子的优化,设置的搜索区间是image.png

https://github.com/deepglint/EasyQuant/blob/f2f2e6cf38/tools/scale\_fine\_tuning.py#L423

和论文中的设置太一样,我看issue上也有人提出了这个疑问:

v2-34d4127997c84129d79d235e77bc3356_1440w.jpg

https://github.com/deepglint/EasyQuant/issues/3

作者回复说推荐按照论文里面的设置,大家如果自己做实验的时候可以结合论文和官方代码。

优化整个网络

然后看下对于整个网络的优化算法流程图:

https://arxiv.org/pdf/2006.16669.pdf

可以看到是交替优化权值和激活,但是这里我看是先固定激活的量化因子,然后优化每一层的权值因子,然后固定每一层的权值因子,再优化逐层优化激活因子,同时在优化激活因子的时候,是每一层激活优化完成之后,更新下一层的量化计算激活值 ,更具体的细节可以参考官方代码。

端上部署 int7 加速

https://arxiv.org/pdf/2006.16669.pdf

上面是论文给出的Arm 端int7CPU推理加速计算流程图。

其中论文中提到了,S M L A L neon 指令表示向量乘加长指令,把两个8bit数据相乘产生16bit结果,然后累加到16bit中间结果上,S A D A L P neon指令,则表示把两个16bit结果相加产生32bit然后累加到32bit累加结果上。

这两个指令我以前是没用过,如果对于具体实现上用的哪些指令感兴趣的话,可以看下 ncnn-int8-e2e:

https://github.com/deepglint/eq-ncnngithub.com

是基于ncnn int8社区版本低比特(小于8bit)量化魔改版。

然后看到端上推理流程图最上角,因为用的是量化到int7 [-63,63],所以8bit除去符号位,还有1bit剩余。这样就可以比量化到int8多累加几次到中间16bit结果上,

v2-1bebd9c5c929e18f94c36cd8f30b6dea_1440w.jpg

https://arxiv.org/pdf/2006.16669.pdf

image.png

https://arxiv.org/pdf/1712.05877.pdf

image.png

实验结果分析

实验设置

论文对比了 TensorRT 的方法,对于TensorRT 量化参数的计算,采用了1000个样本,而对于本论文的方法则是采用了50个样本来搜索量化参数,感觉还是挺惊人的,只用50个样本就能超过TensorRT的方法。

精度对比

https://arxiv.org/pdf/2006.16669.pdf

在imagenet2012验证集上的结果,可以看到不管是量化到int8还是int7,EasyQuant的精度都超过TensorRT,而且很接近浮点的结果。

v2-ffc817ffc50105777a5fb30b8fca7c1e_1440w.jpg

https://arxiv.org/pdf/2006.16669.pdf

然后从物体检测和人脸任务上来看,EasyQuant基本也是超过TensorRT的。

https://arxiv.org/pdf/2006.16669.pdf

实验还对比了 EasyQuant和 训练量化QAT(Quantize Aware Training),可以按到在ResNet50上结果还是不错的,稍微超过QAT。

加速对比

https://arxiv.org/pdf/2006.16669.pdf

然后来看下实际端上推理时候 int8 和 int7 的推理速度对比,可以看到不管是单线程还是多线程,int7 推理的延迟都要少于 int8,有20%\~30%的效率提升的效果,还是挺可观的。

更低bit实验结果

https://arxiv.org/pdf/2006.16669.pdf

论文中还做了更低 bit 的对比实验,从 int8 到 int5,可以看到在不同任务上,EasyQuant 方法大多是优于 TensorRT 的方法的,而且让人惊讶的是图(c),int5 EasyQuant 的精度基本和 int8 相当,没有降多少,这个确实很厉害。

总结

这篇论文提出了一个在低于8bit下精度还能保持比较好的后量化算法,思想相对TensorRT的方法来说更加容易理解,而且实现上也更加的容易,实际端侧推理加速效果也不错。

参考资料

推荐文章

更多AI移动端优化的请关注专栏嵌入式AI以及知乎(@梁德澎)。
推荐阅读
关注数
18849
内容数
1389
嵌入式端AI,包括AI算法在推理框架Tengine,MNN,NCNN,PaddlePaddle及相关芯片上的实现。欢迎加入微信交流群,微信号:aijishu20(备注:嵌入式)
目录
极术微信服务号
关注极术微信号
实时接收点赞提醒和评论通知
安谋科技学堂公众号
关注安谋科技学堂
实时获取安谋科技及 Arm 教学资源
安谋科技招聘公众号
关注安谋科技招聘
实时获取安谋科技中国职位信息