一只小狐狸带你解锁炼丹术&NLP秘籍

作者:苏剑林 (来自追一科技,人称“苏神”)

前言

《Attention is All You Need》一文发布后,基于Multi-Head Attention的Transformer模型开始流行起来,而去年发布的BERT模型更是将Transformer模型的热度推上了又一个高峰。当然,技术的探索是无止境的,改进的工作也相继涌现:有改进预训练任务的,比如XLNET的PLM、ALBERT的SOP等;有改进归一化的,比如Post-Norm向Pre-Norm的改变,以及T5中去掉了Layer Norm里边的beta参数等;也有改进模型结构的,比如Transformer-XL等;有改进训练方式的,比如ALBERT的参数共享等...

以上的这些改动,都是在Attention外部进行改动的,也就是说它们都默认了Attention的合理性,没有对Attention本身进行改动。而本文我们则介绍关于两个新结果:它们针对Multi-Head Attention中可能存在建模瓶颈,提出了不同的方案来改进Multi-Head Attention。两篇论文都来自Google,并且做了相当充分的实验,因此结果应该是相当有说服力的了

arxiv访问慢的小伙伴也可以在订阅号后台回复关键词【0415】下载论文PDF。

再小也不能小key_size

第一个结果来自文章《Low-Rank Bottleneck in Multi-head Attention Models》,它明确地指出了Multi-Head Attention里边的表达能力瓶颈,并提出通过增大key_size的方法来缓解这个瓶颈。

Multi-Head Attention

首先简单回顾一下Multi-Head Attention,Multi-Head Attention的基础是自然是Single-Head Attention,也叫Scaled-Dot Attention,定义如下:

(公式可以左右滑动哦)

其中。而Multi-Head Attention,就是将








分别用




个不同的投影矩阵投影




次,然后分别做




次Single-Head Attention,最后把结果拼接起来,即

Attention里有个瓶颈

在实际使用中,








一般具有相同的特征维度














(即hidden_size),比如BERT Base里边是768;




一般选择12、16、24等,比如BERT base里边是12;确定了






之后,通常的选择是让投影矩阵





















,也就是说,每个Attention Head里边,是将原始的




维投影到








维,然后在进行Attention运算,输出也是








维,最后把













维的结果拼接起来,得到一个




维的输出。这里的








我们通常称为head_size。

在Attention中,关键的一步是

这一步是描述了









的两两向量之间的联系,我们可以将




看成一个二元联合分布(实际上是




个一元分布,不过这个细节并不重要),如果序列长度都为




,也就是每个元有




个可能的取值,那么这个分布共有







个值。

但是,我们将






分别投影到低维后,各自的参数量只有












,总的参数量是










,所以式






就相当于用










的参数量去逼近一个本身有







个值的量,而我们通常有















,尤其是




比较大时更是如此,因此这种建模有点“强模型所难”,这就是原论文中的“低秩瓶颈(Low-Rank Bottleneck)”的含义.

不妨试试增大key_size?

那么,解决办法是什么呢?直接的想法是让










增大,所以要不就是减少head的数目




,要不就是增加hidden_size大小




。但是更多的Attention Head本身也能增强模型的表达能力,所以为了缓解低秩瓶颈而减少




的做法可能得不偿失;如果增加




的话,那自然是能够增强模型整体表达能力的,但整个模型的规模与计算量也会剧增,似乎也不是一个好选择。

那没有其他办法了吗?有!当我们用投影矩阵将








都投影到低维时,前面都是将它们投影到








维,但其实它们的维度不一定要相等,而是只需要保证






的维度相等就行了(因为要做内积),为了区别,我们通常称






的维度为key_size,




的维度才叫head_size,改变key_size的大小而不改变head_size的话,也不影响模型的hidden_size。

所以,这篇论文提出来的解决方法就是增大模型的key_size,它能增加Attention的表达能力,并且不改变模型整体的hidden_size,计算量上也只是稍微增加了一点。

补充说明:事实上原论文考虑的是同时增大key_size和head_size、然后Multi-Head Attention的输出拼接之后再用一个变换矩阵降维,但笔者认为由于拼接降维这一步只是一个线性变换,所以本质上的提升还是来源于增大key_size,所以本文只强调了增大key_size这一步。此外,如果同时增大key_size和head_size,那么会导致计算量和显存消耗都明显增加,而只增大key_size的话,增加的资源消耗就小很多了。

来看看实验结果~

增大key_size这个想法很简单,也容易实现,但是否真的有效呢?我们来看看原论文的实验结果,其实验都是以BERT为baseline的,实验结果图表很多,大家直接看原论文为好,这里只分享比较有代表性的一个:

这个结果显示,如果固定一个比较大的key_size(比如128),那么我们可以调整模型的hidden_size和head数,使得参数量可以跟原始的BERT设计一致,但是效果更优!所以,增加key_size确实是有意义的,哪怕将总体参数量重新调整到原来的一样大,也能一定程度上提升模型的效果。这无疑对我们设计新的Transformer模型(尤其是小规模的模型)有重要的指导作用。

最后,附上我们预训练的两个增大了key_size的RoBERTa小模型,欢迎大家使用(我们称之为RoBERTa+):

https://github.com/ZhuiyiTechnology/pretrained-models

再缺也不能缺Talking

对Multi-Head Attention改进的第二个结果来自论文《Talking-Heads Attention》,这篇论文虽然没有显式地指出它跟前一篇论文的联系,但笔者认为它们事实上在解决同一个问题,只不过思路不一样:它指出当前的Multi-Head Attention每个head的运算是相互孤立的,而通过将它们联系(Talking)起来,则可以得到更强的Attention设计,即标题的“Talking-Heads Attention”。

从单一分布到混合分布

在前一篇论文里边,我们提到了低秩瓶颈,也就是由于key_size太小所以


























表达能力不足,因此softmax之后无法很好地建议完整的二元分布。为了缓解这个问题,除了增大key_size之外,还有没有其他方法呢?有,比如这篇论文使用的混合分布思路。

所谓混合分布,就是多个简单分布的叠加(比如加权平均),它能极大地增强原分布的表达能力。典型的例子是高斯混合模型:我们知道高斯分布只是一个常见的简单分布,但多个高斯分布叠加而成的高斯混合分布(也叫高斯混合模型,GMM)就是一个更强的分布,理论上来说,只要叠加的高斯分布足够多,高斯混合分布能逼近任意概率分布。这个例子告诉我们,想要增加Attention中分布的表达能力,又不想增加key_size,那么可以考虑叠加多个低秩分布

那么“多个”低秩分布哪里来呢?不是有Multi-Head嘛,每个head都带有一个低秩分布,就直接用它们叠加就行了,这就是Talking-Heads Attention了。具体来说,它的形式是:

写起来很复杂,事实上很简单,就是在“










之后、softmax之前”用一个参数矩阵




将各个










的结果叠加一下而已。这样就把原本是孤立的各个Attention Head联系了起来,即做了一个简单的Talking。

对上述公式,做两点补充说明:

1、简单起见,上述公式中笔者省去了缩放因子












,如果有需要,读者自行补充上去即可;

2、更一般的Talking-Heads Attention允许可以在












这一步进行升维,即叠加出多于




个混合分布,然后再用另一个参数矩阵降维,但这并不是特别重要的改进,所以不在主要篇幅介绍。

再来看看实验结果

是不是真的有效,当然还是得靠实验结果来说话。这篇论文的实验阵容可谓空前强大,它同时包含了BERT、ALBERT、T5为baseline的实验结果!众所周知,BERT、ALBERT、T5均是某个时间段的NLP最优模型,尤其是T5还是处在superglue的榜首,并且远超出第二名很多,而这个Talking-Heads Attention则几乎是把它们的辉煌战绩又刷到了一个新高度!

还是那句话,具体的实验结果大家自己看论文去,这里展示一个比较典型的结果:

这个结果显示,使用Talking-Head Attention情况下,保持hidden_size不变,head数目越大(相应地key_size和head_size都越小),效果越优。这看起来跟前一篇增大key_size的结论矛盾,但事实上这正说明了混合分布对分布拟合能力明显提升作用,能够将key_size缩小时本身变弱的单一分布,叠加成拟合能力更强大的分布。当然,这不能说明就直接设key_size=1就好了,因为key_size=1时计算量会远远大于原始的BERT base,应用时需要根据实际情况平衡效果和计算量。

上述表格只是原论文实验结果的冰山一角,这里再放出一个实验表格,让大家感受感受它的实验阵容:

几乎每个任务、每个超参组合都做了实验,并给出实验结果。如此强大的实验阵容,基本上也就只有Google能搞出来了,而且整篇论文明显是浓浓的“T5 Style”(还没看过T5论文的读者,可以去Exploring the Limits of Transfer Learning with a Unified Text-to-Text Transformer》感受一下),果不其然,作者之一Noam Shazeer也正是T5的作者之一。

笔者只想说,这种庞大的实验轰炸,仿佛在向我们宣告着:

不用质疑,该调的参数我们都调了,就我们的Talking-Heads Attention最好~

插曲:神奇的论文画风

话说回来,笔者在Arxiv上首次刷到《Talking-Heads Attention》这篇论文时,第一感觉是一篇垃圾论文。为啥?因为它的画风是这样的:

谁能想象到,一篇如此强大的论文,里边居然没有一条数学公式,取而代之的全是伪代码!!其实伪代码都算不上,感觉更像是直接把实验中的Python代码复制到了论文中,还是复制到论文主体上!笔者印象里,只有那些不入流的水论文才会这样做,所以笔者看到的第一想法就是水文一篇。也就Google的大佬们才能这么任性,要不是耐着心多扫了几眼,要不是不小心扫到了T5等字眼,要不是回去看作者居然清一色是Google的,这篇强大的论文就被笔者当作垃圾论文放到回收站了 不过,任性还是有任性的代价的,这篇实验阵容这么强大又这么有效的论文,发布至今也有一个多月了,但似乎也没什么反响,估计也跟这个任性的风格有关系~

来自文末的小结

本文介绍了两个关于Multi-Head Attention的后续改进工作,虽然改进细节不一致,但可以说它们都是针对“低秩瓶颈”这个问题而提出的,有种殊途同归之感。两个工作都来自Google,实验内容都很丰富,所以结果都比较有说服力,正在做模型结构改进工作的读者可以参考参考。

arxiv访问慢的小伙伴也可以在订阅号后台回复关键词【0415】下载论文PDF。

  • ACL2020 | FastBERT:放飞BERT的推理速度

  • ACL2020 | 对话数据集Mutual:论对话逻辑,BERT还差的很远

  • LayerNorm是Transformer的最优解吗?

  • 如何优雅地编码文本中的位置信息?三种positioanl encoding方法简述

  • 知乎搜索框背后的Query理解和语义召回技术

  • 详解ERNIE-Baidu进化史及应用场景

  • 深入解析GBDT二分类算法(附代码实现)

夕小瑶的卖萌屋

_

关注&星标小夕,带你解锁AI秘籍

订阅号主页下方「撩一下」有惊喜哦

Google | 突破瓶颈,打造更强大的Transformer相关推荐

  1. 固特异宣布收购固铂,打造更强大的美国全球轮胎行业领导者

    固特异轮胎橡胶公司(Goodyear Tire & Rubber Company)和固铂轮胎橡胶公司(Cooper Tire & Rubber Company)宣布,双方已经达成了一项 ...

  2. “双轮驱动”突破瓶颈,智源研究院发布“自然语言处理”重大研究方向,携手京东打造联合实验室...

    2019年10月8日,北京智源人工智能研究院(以下简称"智源研究院")在清华大学FIT楼举行了"自然语言处理"重大研究方向暨"北京智源-京东跨媒体对话 ...

  3. 对前端来说token代表了什么_在线公开课 | 前端工程师如何突破瓶颈更好地变现自己...

    课程概要 此次课程的分享主题是"前端工程师如何突破瓶颈更好地变现提升自己".课程从以下三个方面入手,为大家详解一个前端工程师是如何一步步完善并提升自己的的. 前端工程师所应具备的能 ...

  4. 在线公开课 | 前端工程师如何突破瓶颈更好地变现自己

    在线公开课 | 前端工程师如何突破瓶颈更好地变现自己 原创: 京小云 京东云开发者社区  3天前 课程概要! 此次课程的分享主题是"前端工程师如何突破瓶颈更好地变现提升自己".课程 ...

  5. 如何让大脑更强大?打造最强大脑的5个关键要素

    问大家一个问题,你了解你的大脑吗?我们人生做的每一个决策都需要大脑的参与,大脑是如此的重要,然而绝大多数人对大脑的认知几乎为零.现在就来了解下我们的大脑,学习如何让自己的大脑更强大? 科学家们发现,人 ...

  6. SuperSpider——打造功能强大的爬虫利器

    SuperSpider--打造功能强大的爬虫利器 博文作者:加菲 发布日期:2013-12-11 阅读次数:4506 博文内容: 1.爬虫的介绍 图1-1  爬虫(spider) 网络爬虫(web s ...

  7. Google和微软哪个更可怕?

    Google和微软哪个更可怕? 转自:http://www.bokee.com/ 在国内,没有一个互联网公司可以媲美Google,也没有一个软件公司敢与微软平起平坐.所以,当Google和MSN开始在 ...

  8. 让收费网站去死吧,用google 突破 下载

    让收费网站去死吧,用google 突破 下载 首先打开google,在关键词输入框中输入"index of/"inurl:lib(双引号为英文状态下),选择"搜索简体中文 ...

  9. 用google突破图书馆入口IP限制小技巧

    用google突破图书馆入口IP限制小技巧 很多图书馆都要注册或要本地IP才能浏览或下载图书,有没有另类的快速办法能快速突破图书馆的入口,能随意地下载图书呢? 希望大家在GOOGLE里试试这个:&qu ...

最新文章

  1. java 向量上的坐标点_新高三知识点-点的平移公式
  2. Java程序员从笨鸟到菜鸟之(十一)多线程讲解
  3. 最短路上的统计(Floyd)
  4. 工业界推荐系统必读论文:基于深度学习的推荐模型——DLRM
  5. JSF基于事件的交流:新派方法
  6. 全网独家分享,软件测试就该这么学,3个月进大厂!
  7. ubuntu 9.04 更新源_ubuntu更换中国源
  8. SLF4J: Failed to load class “org.slf4j.impl.StaticLoggerBinder”
  9. Error: could not open `C:\Program Files\Java\jre6\lib\i386\jvm.cfg')
  10. JUnit学习摘要+入门实例
  11. 滑动门套滑动门css,CSS 实现滑动门的实例代码
  12. FPGA学习小例子:38译码器设计与仿真
  13. unrealengine(UE5)虚幻引擎下载安装
  14. MacOS打开多个微信的方法(代码+脚本)
  15. 自控原理入门详解**********
  16. 43岁,外企经理,公司不和我续签了
  17. linux宝塔原理,linux宝塔是干嘛的
  18. 简单图形界面初学 :tkinter+阿里云接口+爬虫,实现全国天气查询
  19. 苹果一体机安装windows7教程
  20. 把机顶盒刷成Linux操作系统

热门文章

  1. 微信企业号开发[二]——获取用户信息
  2. iOS中self.xxx 和 _xxx 下划线的区别
  3. ASP.NET中Request.IsAuthenticated和Request.User.Identity.IsAuthenticated的区别
  4. 个人编程思想理解的片段(主要是面向对象的,参考了许多人的观点,还不成熟,没形成系统,请大家多指点)...
  5. 修改终端服务器的最大连接数
  6. jsp 连接MS server 数据库的例子
  7. 《In Search of an Understandable Consensus Algorithm》翻译
  8. c++整理--虚函数
  9. ubuntu要更新18.04了,lei了lei了~~~
  10. mysql set语句_mysql--乱码解决(6)