邻里注意Transformer(CVPR2023)

news/2024/7/19 10:33:00 标签: transformer, 深度学习, 人工智能

Neighborhood Attention Transformer

  • 摘要
  • 1、介绍
  • 2、相关工作
    • 2.1 新的卷积基线
  • 3、方法
    • 3.1 邻居注意力
    • 3.2 Tiled NA and NATTEN
    • 3.3 邻居注意力Transformer
  • 4、结论

代码

摘要

我们提出邻居注意力(NA),第一个有效和可伸缩的滑动窗口的视觉注意机制。
NA是一种像素级的操作,将自我注意定位到最近的邻近像素上,因此与SA(自注意力)的二次复杂度相比,具有线性的时间和空间复杂度。
与Swin Transformer的窗口自我注意(WSA)不同,滑动窗口模式允许NA的接受域在不需要额外像素位移的情况下增长,并保持平移均方差。
我们开发了NATTEN(邻居注意力扩展),这是一个包含高效c++和CUDA内核的Python包,它允许NA比Swin的WSA运行速度快40%,同时使用的内存少25%。
我们进一步提出了邻居注意力Transformer(NAT),一种新的层次变压器设计基于NA,提高图像分类和下游视觉性能。
NAT实验结果具有一定的竞争力;NAT-Tiny在ImageNet上的准确率达到83.2%,在MSCOCO上达到51.4%的mAP,在ADE20K上达到48.4%的mIoU,这是1.9%的ImageNet准确率,1.0%的COCO mAP,和2.6%的ADE20K mIoU相比相同尺寸的Swin模型。
为了支持更多基于滑动窗口注意力的研究,我们开放了项目的源代码并发布了我们的检查点。

1、介绍

在这里插入图片描述
图 1. 自注意力、(转移的)窗口自注意力和邻域注意力中注意力跨度的图示。自注意力允许每个令牌关注所有事情。 Window Self Attention 将自注意力划分为不重叠的子窗口,然后是 Shifted Window Self Attention,它允许进行感受野扩展所需的窗外交互。邻域注意力将注意力集中在每个标记周围的邻域,引入局部归纳偏差,保持平移等方差,并允许感受野增长而无需额外的操作。

这些高性能的变压器类方法都是基于自我注意(SA),这是原始Transformer[31]的基本构件。SA在嵌入维数方面具有线性复杂度(不包括linear投影),但在tokens数量方面具有二次复杂度。
在视觉范围内,tokens通常与图像分辨率成线性相关。
因此,在严格使用SA(如ViT)的模型中,更高的图像分辨率会导致复杂性和内存使用量的二次增加。
二次复杂性使得这种模型难以适用于后续的视觉任务,如目标检测和分割,在这些任务中,图像分辨率通常比分类分辨率大得多。
另一个问题是,卷积受益于位置和二维空间结构等归纳偏差,而点积的自我注意是一个全局一维操作。
这意味着一些归纳偏差必须通过大量的数据[12]或高级培训技术和增强来学习。
在本研究中,我们回顾了显式滑动窗注意机制,并提出了邻居注意力(NA)。
NA将SA定位到每个像素的最近邻居,它不一定是像素周围的固定窗口。
这种定义上的改变允许所有像素保持相同的注意广度,否则在零填充替代方案(SASA)中,角像素会减少注意广度。
随着邻域大小的增加,NA也接近SA,并且在最大邻域时等于SA。
此外,与阻塞和窗口自注意不同,NA具有保持平移等方差[30]的额外优势。
我们开发了NATTEN,这是一个带有高效c++和CUDA内核的Python包,在使用更少内存的情况下,它允许NA在实践中比Swin的WSA运行得更快。
我们建立了邻居注意力Transformer(NAT),它实现了跨视觉任务的竞争结果。
贡献:
1、==提出邻居注意力(NA):一种简单而灵活的显式滑动窗口注意机制,它将每个像素的注意广度定位到其最近的邻域,随着其广度的增长而接近自我注意,并保持平移方差。==我们将NA的复杂度和内存使用量与自我注意、窗口自我注意和卷积进行了比较。
2、为NA开发高效的c++和CUDA内核,包括tile NA算法,它允许NA运行速度比Swin的WSA快40%,同时使用最多25%的内存。我们将它们发布在一个新的Python包中,用于显式滑动窗口注意机制,NATTEN,以提供易于使用的带有自研支持的模块,这些模块可以插入任何现有的PyTorch管道中。
3、==引入邻居注意力Transformer(NAT),一种新的高效、准确、可伸缩的基于NA的分级变压器。==我们证明了它在分类和下游任务上的有效性。例如,NAT-Tiny在ImageNet上达到了83.2%的top-1准确率,只有4.3 GFLOPs和28M参数,在MS-COCO上是51.4%的box mAP,在ADE20K上是48.4%的mIoU,显著优于Swin Transformer和ConvNeXt[22]。

2、相关工作

2.1 新的卷积基线

Liu et al.[22]提出了一种受Swin等模型影响的新的CNN架构,称为ConvNeXt。
这些模型不是基于注意力的,并且在不同的视觉任务中都优于Swin。
这项工作已经成为一个新的CNN基线,用于对卷积模型和基于注意力的模型进行公平的比较。
我们建议邻居注意力,它通过设计将接受域定位到每个查询周围的窗口,因此不需要额外的技术,例如Swin使用的循环移位。
此外,邻居注意力保持了平移的方差,这是交换效率的方法,如HaloNet和Swin。
我们用NATTEN python包演示了邻居注意力可以比Swin等方法运行得更快,同时使用更少的内存。
我们引入了一个具有这种注意力机制的分层变换式模型,称为邻居注意力Transformer,并展示了它与Swin相比在图像分类、目标检测和语义分割方面的性能。

3、方法

在这一节中,我们介绍了邻居注意力,一种考虑到视觉数据结构的自我注意定位(参见Eq.(1))。与自注意相比,这不仅降低了计算成本,而且还引入了类似于卷积的局部归纳偏差。我们发现,在限制自我注意方面,NA优于之前提出的SASA[25],但在理论成本上是等价的。然后我们介绍我们的Python包NATTEN,它为CPU和GPU加速提供了NA的有效实现。我们讨论了扩展中的新奇之处,以及它如何在使用更少内存的情况下,设法超过Swin的WSA和SWSA的速度。最后我们介绍了我们的模型,邻居注意力Transformer(NAT),它使用这种新的机制代替自我注意。此外,NAT利用了一种多级的分层设计,类似于Swin[21],这意味着特征特征图在不同的层之间向下采样,而不是一次全部采样。与Swin不同,NAT使用重叠卷积对特征特征图进行降采样,而非非重叠(打补丁)的特征特征图,后者已被证明通过引入有用的归纳偏差来提高模型性能[15,34]。
在这里插入图片描述

3.1 邻居注意力

在这里插入图片描述
图 2. 单个像素的邻域注意力 (NA) 与自注意力 (SA) 的查询键值结构图示。 SA 允许每个像素关注所有其他像素,而 NA 则将每个像素的注意力集中到其周围的邻域。因此,每个像素的注意力广度通常与下一个像素不同。

Swin的WSA可以被认为是现有限制自我注意速度最快的方法之一,以降低二次注意成本。它只是简单地划分输入,并将自我注意单独应用到每个分区。WSA需要与移位的变体SWSA配对,后者将这些分隔线移位以允许窗口外的交互。
这对扩大其接受范围至关重要。然而,限制局部自注意的最直接方法是允许每个像素对其邻近像素进行关注。这导致在大多数像素周围有一个动态移动的窗口,这扩大了接受域,因此将不需要手动移动的变体。
此外,与Swin不同,与卷积相似的是,这种动态形式的受限自我注意可以保持平移等方差30。
受此启发,我们引入了邻居注意力(NA)。给定一个输入X∈Rn×d,它是一个矩阵,其行是d维token向量,以及X的线性投影Q, K, V,和相对位置偏差B(i, j),我们定义了第i个输入的注意权值,其邻域大小为K, Ak i,作为第i个输入的查询投影的点积,它的k个最邻近的关键投影:
在这里插入图片描述
其中ρj(i)表示第j个最近的邻居。然后我们定义邻近值vki,作为一个矩阵,它的行是第i个输入的k个最近的邻近值投影:
在这里插入图片描述
邻域大小为k的第i个token的邻居注意力定义为:
在这里插入图片描述
其中√d为缩放参数。对feature map中的每个像素重复此操作。图2和图八展示了这一操作的插图。
从这个定义可以很容易看出,随着k的增长,Ak i趋向于自我注意权重,Vk i趋向于Vi本身,因此邻居注意力趋向于自我注意。这是NA和SASA[25]之间的关键区别,每个像素在输入周围使用填充来处理边缘情况。正是由于这种差异,当窗口大小增加时,NA会接近于自我注意,这在SASA中并不适用,因为输入周围的填充为零。

3.2 Tiled NA and NATTEN

在过去,以像素方式限制自我注意还没有得到很好的研究,主要是因为它被认为是一种昂贵的操作[21,25,30],需要更低层次的重新实现。这是因为自我关注本身被分解为矩阵乘法,这是一种很容易在加速器上并行化的操作,并且在计算软件中为不同的用例定义了大量的高效算法(举几个例子:LAPACK、cuBLAS、cutass)。此外,大多数深度学习平台,如PyTorch,都是在此类软件和附加包(如cuDNN)之上编写的。这对研究人员非常有帮助,因为它允许他们使用操作的抽象,如矩阵乘法或卷积,而后端根据他们的硬件、软件和用例决定运行哪个算法。它们通常还能处理自动梯度计算,这使得设计和训练深度神经网络非常简单。由于NA的像素级结构(以及其他像素级注意机制,如SASA[25]),以及NA中邻域定义的新奇性,在这些平台上实现NA的唯一方法是堆叠大量高效的操作来提取邻域,并将其存储为一个中间张量,然后计算注意力。
这会导致操作非常慢,内存使用量呈指数增长。为了应对这些挑战,我们开发了一套高效的CPU和CUDA内核,并将它们打包为Python包(邻居注意力扩展(NATTEN))。NATTEN包括半精度支持,对1D和2D数据的支持,以及与PyTorch的自动兼容集成。这意味着用户可以简单地将NA导入为PyTorch模块,并将其集成到现有的管道中。我们还补充说,SASA也可以很容易地用这个包实现,而不需要对底层内核进行更改(只需将输入填充为零),因为这是NA的一种特殊情况。反之则不成立。它还包括我们的平铺NA算法,它通过将不重叠的查询平铺加载到共享内存来计算邻居的注意力权重,以最小化全局内存读取。与简单的实现相比,平放的NA可以减少一个数量级的延迟(技术细节见附录A),并且它允许基于NA的模型比类似的Swin模型运行速度快40%(见图4)。NATTEN的开源网址是:https://github.com/SHI-Labs/NATTEN。

3.3 邻居注意力Transformer

在这里插入图片描述
图 5.我们的模型 NAT 及其分层设计的概述。该模型从卷积下采样器开始,然后进入 4 个连续级别,每个级别由多个 NAT 块组成,这些块是类似变压器的编码器层。每层由多头邻域注意力(NA)、多层感知器(MLP)、每个模块之前的层规范(LN)和跳过连接组成。在各个级别之间,特征图被下采样至其空间大小的一半,而其深度则加倍。这样可以更轻松地通过特征金字塔转移到下游任务。
NAT 使用 2 个连续的 3 × 3 卷积(步幅为 2 × 2)嵌入输入,导致空间大小为输入大小的 1/4。这类似于使用补丁和具有 4 × 4 补丁的嵌入层,但它利用重叠卷积而不是非重叠卷积来引入有用的归纳偏差 [15,34]。另一方面,使用重叠卷积会增加成本,并且两个卷积会产生更多参数。然而,我们通过重新配置模型来处理这个问题,从而实现更好的权衡。 NAT 由 4 个级别组成,每个级别后面都有一个下采样器(最后一个除外)。下采样器将空间大小减少一半,同时通道数量增加一倍。我们使用步长为 2 × 2 的 3 × 3 卷积,而不是 Swin 使用的 2 × 2 非重叠卷积(补丁合并)。由于分词器下采样为 4 倍,因此我们的模型生成大小为 h 4 × w 4 、 h 8 × w 8 、 h 16 × w 16 和 h 32 × w 32 的特征图。这一变化是由之前成功的 CNN 结构推动的,随后是其他基于分层注意力的方法,例如 PVT [32]、ViL [38] 和 Swin Transformer [21]。此外,我们使用 LayerScale [29] 来保证较大变体的稳定性。图 5 展示了整体网络架构。我们在表 1 中总结了不同 NAT 变体。
在这里插入图片描述

4、结论

在本文中,我们提出了邻域注意力(NA),这是第一个高效且可扩展的视觉滑动窗口注意力机制。 NA 是一种逐像素操作,它将每个像素的自注意力定位到其最近邻域,因此具有线性复杂度。与阻塞(HaloNet)和窗口自注意力(Swin)不同,它还引入了局部归纳偏差并保持平移等方差。与 SASA 不同,NA 随着窗口大小的增加而接近自注意力,并且在极端情况下不限制注意力跨度。我们通过开发 NATTEN 来挑战显式滑动窗口注意力模式效率不高或可并行化的普遍观念 [21]。通过使用 NATTEN,基于 NA 的模型可以比现有替代方案运行得更快,尽管后者主要运行在构建于较低级别计算包之上的高度优化的深度学习库上。我们还提出了 Neighborhood Attention Transformer (NAT) 并展示了此类模型的强大功能:NAT 在图像分类方面优于 Swin Transformer 和 ConvNeXt,并且在下游视觉任务中优于或与两者竞争。我们开源整个项目,以鼓励在这个方向进行更多研究。


http://www.niftyadmin.cn/n/5176184.html

相关文章

zotero跨Windows设备数据同步(利用OneDrive、百度云同步空间等云服务)

zotero跨Windows设备数据同步(利用OneDrive、百度云同步空间等云服务) 特别注意 不能在多个设备同步使用zotero,否则会导致同步出现异常。 基本原理 同步zotero的数据,即同步全部的文献和笔记、高亮标记信息。而这两类数据分别…

单片机定时器讲解和实现

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、计数器是什么?二、单片机定时器结构2.1***两个8位如何合成16位,16位如何分成两个8位***2.2 计数器的位数组合?2.3 定时功…

Git忽略文件.gitignore的使用

1.为什么使用? 当你使用git add .的时候有没有遇到把你不想提交的文件也添加到了缓存中去?比如项目的本地配置信息,如果你上传到Git中去其他人pull下来的时候就会和他本地的配置有冲突,所以这样的个性化配置文件我们一般不把它推送到git服务…

【从零开始学习Linux】一文带你了解Shell外壳及用户权限(二)

🚩纸上得来终觉浅, 绝知此事要躬行。 🌟主页:June-Frost 🚀专栏:Linux入门 🔭【从零开始学习Linux】系列均属于Linux入门,主要包含Linux操作系统下的指令、操作、权限以及开发工具&a…

“谐波”分析治理,电能质量在线监测

安科瑞 崔丽洁 摘要:在国家鼓励半导体材料国产化的政策导向下,本土半导体材料厂商不断提升半导体产品技术水平和研发能力,逐渐打破了国外半导体厂商的垄断格局,推进中国半导体材料国产化进程,促进中国半导体行业的发展…

2023数字科技生态大会-数字安全论坛 学习笔记

监管合规->价值创造的方向,在安全领域的发展方向-安全运营服务型 ICT->数字->数据 数字安全:网络安全数据安全 传统信息化以计算为核心,数字化以数据为核心 数字安全技术发展十大趋势: 一、 数字安全技术政策环境将不…

使用Filter实现登录验证基础-不包含角色、权限等

1、什么是Filter Filter可认为是Servlet的一种特殊用法,主要是对用户发起的请求进行预处理或后处理,意思就是在请求到达用户想请求的地址之前先进入Filter,或者在离开用户请求之后进入Filter。Filter类似于门卫,你在进入之前门卫…

LGSVL Python API 使用

1. References [1] LGSVL-python API使用方法 - 简书 [2] GitHub - lgsvl/PythonAPI: Python API for Simulator