一文彻底搞懂深度学习 - 自注意力(Self- Attention) 原创

发布于 2024-11-27 13:00
浏览
0收藏

一文彻底搞懂深度学习 - 自注意力(Self- Attention)-AI.x社区

在深度学习中,自注意力机制​允许模型在处理序列数据时,通过计算序列中不同位置元素之间的相关性得分动态地调整对每个元素的关注程度,从而捕捉序列内部的复杂依赖关系。

自注意力机制与注意力机制在处理对象和应用场景上存在差异,自注意力机制更侧重于处理序列内部元素之间的相互作用。

一文彻底搞懂深度学习 - 自注意力(Self- Attention)-AI.x社区

Self- Attention

一、自注意力机制

自注意力机制(Self- Attention)是什么?自注意力机制能够动态地捕捉序列中不同位置元素之间的依赖关系,并根据这些依赖关系生成新的序列表示。

它之所以被称为“自注意力”,是因为它在单一序列中通过计算序列元素之间相互依赖关系来生成新的特征表示。这与传统的注意力机制有所不同,后者通常涉及两个序列之间的交互。

一文彻底搞懂深度学习 - 自注意力(Self- Attention)-AI.x社区

自注意力机制和传统注意力机制区别是什么?传统注意力机制通常涉及目标元素(输出)与源元素(输入)之间的交互,而自注意力机制则专注于输入序列或输出序列内部元素之间的相互作用,其查询和键均来自同一组元素

  • 传统注意力机制:通常发生在目标元素(输出)与源元素(输入)之间。在机器翻译等任务中,注意力机制的查询和键往往来自不同的来源,例如在中译英模型中,查询是中文单词的特征,而键是英文单词的特征。

一文彻底搞懂深度学习 - 自注意力(Self- Attention)-AI.x社区

  • 自注意力机制:是在输入序列内部元素之间或者输出序列内部元素之间的相互作用。自注意力机制的查询和键来自同一组元素,即查询和键都是同一序列(如一句话中的词元或同一张图像中的不同patch)的特征,彼此之间进行注意力计算。

一文彻底搞懂深度学习 - 自注意力(Self- Attention)-AI.x社区

二、注意力分数

如何实现注意力机制?在自注意力机制中,通过缩放点积计算注意力得分并利用这些得分对值向量进行加权求和,从而实现了自注意力机制,它能够捕捉序列内部元素之间的依赖关系。

一文彻底搞懂深度学习 - 自注意力(Self- Attention)-AI.x社区

注意力分数是什么注意力分数用来量化注意力机制中某一部分信息被关注的程度,反映了信息在注意力机制中的重要性。在注意力机制中,模型会根据注意力分数来决定对不同输入信息的关注程度。

一文彻底搞懂深度学习 - 自注意力(Self- Attention)-AI.x社区

Q(Query)、K(Key)、V(Value)通过映射矩阵得到相应的向量,通过计算Q与K的点积相似度并经过softmax归一化得到权重,最后使用这些权重对V进行加权求和得到输出。

一文彻底搞懂深度学习 - 自注意力(Self- Attention)-AI.x社区

Q、K、V计算过程是什么?对于输入序列的每个单词,通过计算其Query与所有单词Key的点积得到注意力分数,经Softmax归一化后得到注意力权重,再用这些权重对Value向量进行加权求和,以得到包含丰富上下文信息的新单词表示。

  • 生成Q、K、V向量:对于输入序列中的每个单词,都会生成对应的Query(查询)、Key(键)和Value(值)向量。这些向量通常是通过将单词的嵌入向量(Embedding Vector)输入到一个线性变换层得到的。
  • 计算Q、K的点积(注意力分数):计算Query向量与序列中所有单词的Key向量之间的点积,得到一个分数。这个分数反映了Query向量与每个Key向量之间的相似度,即每个单词与当前位置单词的关联程度。
  • Softmax函数归一化(注意力权重):这些分数会经过一个Softmax函数进行归一化,得到每个单词的注意力权重。这些权重表示了在理解当前单词时,应该给予序列中其他单词多大的关注。​
  • 注意力权重加权求和(加权和向量):这些注意力权重与对应的Value向量进行加权求和,得到一个加权和向量。这个加权和向量会被用作当前单词的新表示,包含了更丰富的上下文信息。

一文彻底搞懂深度学习 - 自注意力(Self- Attention)-AI.x社区



本文转载自公众号架构师带你玩转AI 作者:AllenTang

原文链接:​​https://mp.weixin.qq.com/s/9iAlFN1184c69mTD0OJ3yA​

©著作权归作者所有,如需转载,请注明出处,否则将追究法律责任
收藏
回复
举报
回复
相关推荐