IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> I-BERT -> 正文阅读

[人工智能]I-BERT

背景

本文介绍ICML2021 I-BERT:?Integer-only BERT Quantization

文章目的是对BERT进行更彻底的量化和整型计算;

作者认为之前的量化方案没有对gelu、softmax这些非线性操作进行量化计算(如下图1),即保持了float类型的计算,不仅影响计算效率,而且不能部署到某些只支持整型计算的芯片上;

图1:I-BERT的改进点
???

作者采用的量化方案是 8bits 对称量化;


已有方案和不足

作者主要解决GELU、softmax这两类非线性层的量化问题;

先来看看GELU的表达式,如下,erf被称为error function

\\GELU(x) = x*\frac{1}{2}[1+erf(\frac{x}{\sqrt2})]

其中??\\ erf = \frac{2}{\sqrt\pi}\int^x_0e^{-t^2}dt \in [-1, 1] \\

且??\\ \int^{\infty }_0e^{-t^2}dt = \frac{\sqrt{\pi}}{2}

GELU本身难以直接实现量化,强行量化会导致较大精度损失;

不像线性层(如矩阵乘积、分段线性的RELU等),利用线性性质可以较好地反量化到float计算结果( 作者举例?MatMul(Sq) = S*MatMul(q),其中x=Sq,S为scale,q为x的量化值 );

已有的一些近似GELU的方案,包括:

- sigmoid近似,如下,引入非线性sigmoid,仍然不好整型计算

\\ GELU(x) = x\sigma(1.702x)\\ where \space\ \sigma(x) = sigmoid(x)

- ReLU6近似,如下,使用ReLU6,虽然可以整型化,但是效果不佳;该方案也被称为h-GELU

h-GELU(x) := x\frac{ReLU6(1.702x+3)}{6} \approx GELU(x)

下图2左图展示了h-GELU的缺点

图2:几种激活函数及指数函数量化前后对比

GELU的解决方案

作者通过分析,认为可以引入二阶多项式对erf进行近似,进一步对GELU进行近似,计算方式如下

\\\underset{a,b,c}{min}\frac{1}{2}||GELU(x) - x*\frac{1}{2}[1+L(\frac{x}{\sqrt2})]||^2_2\\ s.t. \space\ \space\ \space\ L(x) = a(x+b)^2 + c

这个想法来自于任意函数可由多项式函数拟合的理论,将该类型多项式称为interpolating polynomials(插值多项式);详情请移步原文;

直接优化上式得到的结果并不理想,原因是erf的定义域是实域范围;

考虑到erf的值域在[-1, 1],且erf是个奇函数,即

erf(-x) = -erf(x)

因此作者通过设计正实数域部分,并推广到负实数域,得到如下L(x),

\\L(x) = sgn(x)*\{a*[clip(|x|, max=-b) + b]^2 + 1\},其中

\\ a= -0.2888 \\b= -1.769

clip中的max表示|x|最大取值为-b;

因此L(x) \in [-1, 1],且为奇函数;

a、b是通过找一些GELU上的点来进行拟合求解的;

如上可得,

i-GELU(x) := x*\frac{1}{2}[1 + L(\frac{x}{\sqrt2})]


i-GELU的量化方案

有了GELU的多项式表达形式,就可以开始设计量化方案了;

L(x)是个多项式,因此得先知道怎么对多项式量化;

作者给出了多项式量化算法 I-POLY,如下

图3:多项式量化算法 I-POLY
?

可以验证?q_{out}S_{out} \approx a(x+b)^2 + c

因此任意2阶多项式的量化、反量化都可以采用上述算法;

(注:个人感觉这里的量化属于一种为了计算量化而量化;计算过程没问题,就是感觉是故意构造出来的那种,q_out和S_out都未必是多项式结果的真实量化值和scale)

------

有了多项式量化方法,就可以继续实现I-GELU的量化方案了,计算过程如下

图4:I-GELU的实现

调用栈为 I-GELU -> I-ERF -> I-POLY

注意图4算法中的一些实现小技巧,如

?\frac{x}{\sqrt2} = q * \frac{S}{\sqrt2}

??\\x' \\= clip(|x|, max=-b) \\ = S * clip(|q|, max=-b/S) \\= S*q'

注意到上式 max=-b/S,可能得改成 max=round(-b/S),不然q’没法保证是整型。。。

------

以上即为I-GELU的实现过程,效果如下

图5:I-GELU效果对比
????


SOFTMAX的解决方案

- 利用高阶多项式进行近似,可用场景很有限;


SOFTMAX的量化方案

为了数值稳定性,作者首先对softmax进行处理,如下

Softmax(\vec{x})_i = \frac{e^{x_i - x_{max}}}{\sum^{k}_{j=1}e^{x_j - x_{max}}}

x_{max} = max_i(\vec{x})

值得一提的是,\tilde{x} = x_i - x_{max} < 0

对于一个非正实数\tilde{x},可以通过下式对其进行近似

\tilde{x} = -ln2*z + p

其中z(商)是一个非负整数,p(余数)取值范围?(-ln2, 0]

则有

e^{\tilde{x}} = 2^{-z}*e^p = e^p >> z

上式 >> 表示右移操作;

进一步,如果能将e^p表示为整型计算,那么就能对所有e^{\tilde{x}}以及Softmax进行整型计算了;

而且?e^p中 p的取值范围 相对x或者\tilde{x}?缩小了很多,可以更好地做近似;

回想GELU,作者提出通过 2阶多项式近似非线性函数;这里也可以这样做;

作者寻找e^p的近似二阶多项式的方法,是通过在(-ln2, 0]范围内计算下式最优解:

?\\\underset{a,b,c}{min}||e^p - L(p)||^2_2 \\s.t. \space\ \space\ L(p) = a(p+b)^2+c

最终得到

L(p) = 0.3585(p+1.353)^2 + 0.344

i-exp(\tilde{x}) := L(p) >> z

其中?z = \left \lfloor \frac{\tilde{x}}{-ln2} \right \rfloorp = \tilde{x} + ln2*z

图2右图展示了上述近似有着很好的效果;

多项式的量化计算方法 I-POLY 在上面已经介绍过了,所以整个Softmax的量化计算方法为

图6:I-SOFTMAX的实现

?基本思想和I-GELU差不多

#TODO#:最后一步?q_{out}S_{out} \approx Softmax(x)?好像有点问题。。。


LayerNorm的量化方案?

?- 待续


I-BERT的实现解析

- 将放在另一篇文章中讨论


总结

- 本文介绍了I-BERT的改进点及 GELU/SOFTMAX 的整型化计算 实现方法;

- 主要思想是通过2阶多项式进行近似,再对2阶多项式进行量化计算;

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-06-25 18:06:59  更:2022-06-25 18:10:47 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 14:45:15-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码