用MLP代替掉Self-Attention

2021-05-17 12:20:05 浏览数 (1)

用MLP代替掉Self-Attention

这次介绍的清华的一个工作 “Beyond Self-attention: External Attention using Two Linear Layers for Visual Tasks”

用两个线性层代替掉Self-Attention机制,最终实现了在保持精度的同时实现速度的提升。

这个工作让人意外的是,我们可以使用MLP代替掉Attention机制,这使我们应该重新好好考虑Attention带来的性能提升的本质。

Transformer中的Self-Attention机制

首先,如下图所示:

self-attention

我们给出其形式化的结果:

其中, 同时

这里,我们给出一个简化版本,如下图所示:

simplified self-attention

也就是将 都以输入特征 代替掉,其形式化为:

然而,这里面的计算复杂度为 ,这是Attention机制的一个较大的缺点。

外部注意力 (External Attention)

如下图所示:

external-attention

引入了两个矩阵 以及 , 代替掉原来的

这里直接给出其形式化:

这种设计,将复杂度降低到, 该工作发现,当 的时候,仍然能够保持足够的精度。

其中的 操作是先对列进行Softmax,然后对行进行归一化。

实验分析

首先,文章将Transformer中的Attention机制替换掉,然后在各类任务上进行测试,包括:

  • 图像分类
  • 语义分割
  • 图像生成
  • 点云分类
  • 点云分割

这里只给出部分结果,简单说明一下替换后的精度损失情况。

图像分类

image-cls

语义分割

semantic-segmentation

图像生成

generation

可以看到,在不同的任务上,基本上不会有精度损失。

0 人点赞