【论文】attention is all you need

news2025/1/16 3:58:20

重点在第三节

  • attention is all you need
    • 摘要
    • 1. 绪论
    • 2. 背景
    • 3. 模型架构
      • 3.1 编码器和解码器堆叠
    • 3.2 注意力
        • 3.2.1 缩放点积注意力(Scaled Dot-Product Attention)
        • 3.2.2 多头注意力机制
        • 3.2.3 模型中注意力的应用
      • 3.3 职位感知前馈网络(Position-wise Feed-Forward Networks)
      • 3.4 嵌入和Softmax(Embeddings and Softmax)
      • 3.5 站位编码(Positional Encoding)
    • 4. Why Self-Attention
    • 5. 训练
      • 5.1 训练数据与批处理
      • 5.2 Hardware and Schedule
      • 5.3 optimizer
      • 5.4 Regularization
    • 6. 结果
      • 6.1 机器翻译
      • 6.2 模型变量
      • 6.3 英语成分句法分析
    • 7. 结论
  • 提问
    • 1. 顺序计算的基本限制是什么
    • 2. 本文的Transformer模型结构是什么
    • 3. 残差链接是如何实现的
    • 4. 缩放点积注意力是什么,如何实现,有何效果
    • 5. 多头注意力相比于缩放点积注意力有什么提升
    • 6. Embeddings一词如何理解
    • 7. 什么是Transformer

attention is all you need

摘要

主流的序列传导模型基于包含编码器和解码器的复杂循环或卷积神经网络,最佳性能的模型还通过注意机制将编码器和解码器连接。我们提出了一种新的简单网络架构,Transformer,仅基于注意机制,完全放弃循环和卷积。在两个机器翻译任务上的实验表明,这些模型在质量上优于其他模型,同时更易并行化和需要较少的训练时间。我们的模型在 WMT 2014 英文-德语翻译任务上实现了 28.4 BLEU 的成绩,比现有最佳结果(包括集成)提高了 2 BLEU 以上。在 WMT 2014 英-Fr 翻译任务中,我们的模型在 8 个 GPU 上训练 3.5 天后,创造了新的单模型最佳 BLEU 分数 41.8,仅需最佳模型的一小部分训练成本。我们展示了 Transformer 的泛化能力,通过成功将其应用到英文组成语句分析,无论是使用大量或有限的训练数据。

1. 绪论

递归神经网络、长短时记忆以及门循环神经网络已经被确定为在序列建模和传导问题中,例如语言建模和机器翻译方面的最先进方法。此后,已经有大量的研究工作继续推动递归语言模型和编码器-解码器架构的边界。

现有的模型通常会按输入和输出序列的符号位置来分解计算。将位置与计算时间的步骤对齐,它们生成一个隐状态序列 h t h_t ht,作为上一个隐状态 h t − 1 h_{t−1} ht1和位置t的输入的函数。这种内在的序列特性排除了在训练例子中的并行化,这在较长的序列长度时变得至关重要,因为内存限制对跨例子批处理造成了影响。最近的研究通过分解技巧和条件计算取得了显著的计算效率提高,同时在后一种情况下也提高了模型性能。然而,顺序计算的基本限制仍然存在。

注意机制已成为各种任务中引人注目的序列建模和转导模型的重要组成部分,在这些模型中,它能够无视输入或输出序列的距离建模依赖关系。然而,在除少数情况外,这种注意机制通常是与循环网络一起使用的。

在本研究中,我们提出了Transformer模型架构,它放弃了循环结构,完全依赖注意力机制来建立输入和输出之间的全局依赖关系。该模型允许更大程度的并行化,只需使用8个P100 GPU进行12小时训练,就能取得高质量的翻译效果,达到了一种新的技术水平。

2. 背景

将顺序计算的减少作为目标也是 Extended Neural GPU 、ByteNet 和 ConvS2S的基础,这些模型都使用卷积神经网络作为基本构建块,用于在所有输入和输出位置上并行计算隐藏表示。在这些模型中,从任意两个输入或输出位置关联信号所需的操作数量随位置间距离增长,对于 ConvS2S 是线性的,对于 ByteNet 是对数的。这使得学习远距离位置之间的依赖关系更加困难 。在 Transformer 中,这被减少到一定数量的操作,尽管由于对注意力加权位置的平均影响而导致有效分辨率降低,我们通过第3.2节中描述的 Multi-Head Attention 技术来抵消这种影响。

自我注意力,有时也称为内部注意力,是一种注意机制,涉及单个序列的不同位置,以计算序列的表示。 自我注意力已成功地应用于多项任务,包括阅读理解、摘要总结、文本蕴含和学习与任务无关的句子表示。

端到端记忆网络基于循环注意机制而不是序列对齐循环,已被证明在简单语言问答和语言建模任务中表现良好。

据我们所知,Transformer是第一个完全依赖于自注意力来计算其输入和输出表示的跨域模型,而不需要使用序列对齐的递归神经网络或卷积技术。在接下来的章节中,我们将描述Transformer,解释自注意力的实现原理,并讨论其优势。

3. 模型架构

大多数具有竞争力的神经序列转换模型均具备编码器-解码器结构。这里,编码器将符号表示的输入序列(x1, …, xn)映射到一系列连续表示z = (z1, …, zn)。给定z,解码器随后逐个元素生成符号的输出序列(y1, …, ym)。在每个步骤中,模型是自回归的,在生成下一个元素时,会将先前生成的符号消耗作为附加输入。Transformer使用堆叠的自我注意力和点对点全连接层作为编码器和解码器的总体架构,分别表示在Figure 1的左半部分和右半部分。
在这里插入图片描述

3.1 编码器和解码器堆叠

编码器:编码器由N = 6个相同的层堆叠而成,每个层包括两个子层。第一个子层是多头自注意力机制,第二个子层是一个简单的位置感知全连接前馈网络。我们采用残差连接来连接这两个子层,接着进行层归一化。也就是说,每个子层的输出都是 LayerNorm(x + Sublayer(x)),其中 Sublayer(x) 是该子层实现的函数。为了方便这些残差连接,模型中的所有子层以及嵌入层的输出维度均为$ d_{model }$= 512。

解码器:解码器还由N = 6个相同层数的堆叠组成。除了每个编码器层中的两个子层外,解码器还插入了一个第三个子层,用于在编码器堆叠的输出上执行多头注意力。与编码器类似,我们在每个子层周围使用残差连接,然后进行层归一化。我们还修改了解码器堆叠中的自我注意子层,以防止参照后续位置。这种屏蔽功能,再加上输出嵌入被一个位置偏移,确保位置i的预测仅依赖于小于i的已知输出位置。

3.2 注意力

注意力机制可被描述为将一个query或一组键值对映射到输出的过程,其中query、keys、 values和output均为向量。输出是值的加权和,其中分配给每个值的权重是由查询与相应键的兼容性函数计算得出的。
在这里插入图片描述

3.2.1 缩放点积注意力(Scaled Dot-Product Attention)

我们将特别关注点称为“缩放点积注意力”(图2)。输入由查询和尺寸为 d k d_k dk的键以及尺寸为 d v d_v dv的值组成。我们计算查询与所有键的点积,每个点积除以 d k \sqrt{d_k} dk ,并应用softmax函数以获得值的权重。

实际应用中,我们同时计算查询集合的注意力函数,将其打包成矩阵Q。键和值也被打包成矩阵K和V。我们计算输出矩阵如下:在这里插入图片描述
最常用的注意力函数有additive注意力和点积(乘法)注意力[2]。点积注意力与我们的算法相同,唯一不同之处在于缩放因子为 1 d k \cfrac{1}{\sqrt{d_k}} dk 1。加性注意力使用单隐藏层的前馈网络计算兼容性函数。虽然两者在理论复杂度上相似,但在实践中,点积注意力更快且更节省空间,因为可以使用高度优化的矩阵乘法代码实现。

虽然对于小值的 d k d_k dk,这两个机制表现相似,但在较大的 d k d_k dk值情况下,加性注意力机制优于不经缩放的点乘注意力机制。我们怀疑当 d k d_k dk越大时,点乘运算结果会变得很大,将softmax函数推向梯度极小的区域;为平衡此影响,我们需要用 1 d k \cfrac{1}{\sqrt{d_k}} dk 1对点乘结果进行缩放。

3.2.2 多头注意力机制

与使用 d m o d e l d_{model} dmodel维度的键、值和查询执行单一的注意力函数不同,我们发现将查询、键和值线性投影h次,每次使用不同的可学习线性投影投影到 d k d_k dk d k d_k dk d v d_v dv维度,有益于提高性能。然后,对这些投影版本的查询、键和值进行并行的注意力函数,产生 d v d_v dv维度的输出值。这些输出值被串联起来,再次进行投影,从而得到最终的值,如图2所示。

多头注意机制允许模型联合关注不同表征空间中的信息,而这些信息位于不同的位置。而单一注意力头则会受到平均值的抑制,从而无法实现上述联合关注。
在这里插入图片描述

3.2.3 模型中注意力的应用

Transformer 在三种不同的方式中使用多头注意力。

  • 在“编码器-解码器注意力”层中,查询来自前一个解码器层,而存储键和值则来自编码器的输出。这使得解码器中的每个位置都可以关注输入序列中的所有位置。这类似于序列到序列模型中的典型编码器-解码器注意机。
  • 编码器包含自注意层。在自注意层中,所有的键、值和查询都来自同一位置,即编码器中前一层的输出。编码器中的每个位置都可以关注到编码器前一层中的所有位置。
  • 编码器包含自注意层。在自注意层中,所有的键、值和查询都来自同一位置,即编码器中前一层的输出。编码器中的每个位置都可以关注到编码器前一层中的所有位置。

3.3 职位感知前馈网络(Position-wise Feed-Forward Networks)

除了注意子层外,我们的编码器和解码器中的每个层都包含了一个完全连接的前馈神经网络,它独立且相同地应用于每个位置。它由两个线性变换和一个介于两者之间的ReLU激活函数组成。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-803K7wi4-1686468840128)(C:\Users\Administration\AppData\Roaming\Typora\typora-user-images\image-20230609191118461.png)]

尽管不同位置上的线性变换相同,但它们在每个层中使用不同的参数。另一种描述方式是将其视为两个卷积核大小为1的卷积运算。输入和输出的维度为 d m o d e l = 512 d_{model} = 512 dmodel=512,而内层的维度为 d f f = 2048 d_{ff} = 2048 dff=2048

3.4 嵌入和Softmax(Embeddings and Softmax)

与其他序列传导模型类似,我们使用学习到的Embeddings将输入标记和输出标记转换为维度为 d m o d e l d_{model} dmodel的向量。我们还使用通常的学习线性变换和softmax函数将解码器输出转换为预测的下一个标记概率。在我们的模型中,我们在两个嵌入层和预softmax线性变换之间共享相同的权重矩阵。在嵌入层中,我们将这些权重乘以 d m o d e l \sqrt{d_{model}} dmodel

3.5 站位编码(Positional Encoding)

由于我们的模型没有循环和卷积,为了让模型利用序列的顺序,我们必须注入一些关于 Table 1 的相对或绝对位置的信息:不同层类型的最大路径长度、每层复杂度以及最小顺序操作数量。其中,n 是序列长度,d 是表示维度,k 是卷积核大小,r 是限制自注意力中邻域的大小。在这里插入图片描述
为此,我们在编码器和解码器堆栈底部的输入嵌入中添加“位置编码”。位置编码具有与嵌入相同的维度 d m o d e l d_{model} dmodel,这样两者就可以相加。有许多位置编码的选择,包括可以学习和固定的。

在这项工作中,我们使用不同频率的正弦和余弦函数:

在这里插入图片描述
其中,pos 表示位置,i 表示维度。也就是说,位置编码的每个维度都与正弦波相对应。波长从 2π 到 10000 · 2π 形成了一种几何级数。我们选择这个函数是因为我们假设这可以让模型轻松学习相对位置的关注,因为对于任何固定的偏移量 k, P E p o s + k PE_{pos+k} PEpos+k 可以表示为 P E p o s PE_{pos} PEpos 的线性函数。

我们还尝试使用学习得到的位置编码来替代,同时发现两个版本产生的结果几乎相同(参见表3中(E)行)。我们选择正弦版本,因为它可以让模型在超出训练范围的序列长度上进行外推。

4. Why Self-Attention

在本节中,我们将自我注意力层与常用于映射一个可变长度符号表示序列(x1,…,xn)到另一个相等长度序列(z1,…,zn)的循环和卷积层进行比较,其中xi, z i ∈ R d z_i∈R^d ziRd,例如典型序列传导编码器或解码器中的隐藏层。为了激励我们使用Self-Attention,我们考虑三个希望实现的目标。

其中一个是每层的总计算复杂度,另一个是可以并行计算的计算量,其测量单位为所需的最小顺序操作数。

第三个问题是网络中远程依赖关系之间的路径长度。学习远程依赖关系是许多序列转换任务中的关键挑战。影响学习此类依赖关系的一个关键因素是前向和后向信号在网络中必须穿越的路径的长度。这些路径在输入和输出序列中的任意位置之间的长度越短,学习远程依赖关系就越容易[12]。因此,我们还比较不同层类型组成的网络中任何两个输入和输出位置之间的最大路径长度。

如表1所示,自注意力层将所有位置连接起来,并执行一定数量的连续操作,而递归层需要O(n)个连续操作。在计算复杂度方面,当序列长度n小于表示维数d时,自注意力层比递归层更快,这在现代机器翻译模型中使用的句子表示中最常见,例如字片段表示[38]和字节对表示[31]。为了提高在涉及非常长的序列的任务中的计算性能,自注意力可以被限制为仅考虑以输出位置为中心的输入序列大小为r的邻域。这将增加最大路径长度到O(n / r)。我们计划在未来的工作中进一步研究这种方法。

具有核宽度 k < n 的单个卷积层无法连接所有输入和输出位置的所有对。在连续卷积的情况下,需要 O(n/k) 层卷积层,而在扩张卷积的情况下,需要 O ( l o g k ( n ) ) O(log_k(n)) O(logk(n)) 层,这会增加网络中任意两个位置之间最长路径的长度。相较于循环层,卷积层通常更加消耗资源,其消耗率为 k 倍。然而,分离卷积 [6] 可以极大地降低计算复杂度,至$ O(k · n · d + n · d^2)$。即便在 k = n 的情况下,分离卷积的计算复杂度仍然等同于自注意力层和逐点前馈层的结合,这也是我们模型采用的方法。

作为副产品,自我注意力机制能够产生更加易于解释的模型。我们检查了我们模型中的注意力分布,并在附录中提供和讨论了示例。不仅每个注意力头明显学会执行不同的任务,许多头也似乎表现出与句子的句法和语义结构相关的行为。

5. 训练

本节介绍我们模型的训练体系。

5.1 训练数据与批处理

我们使用了标准的WMT 2014年英德数据集,其中包含约450万个句子对。句子是使用字节对编码[3]进行编码的,该编码采用了共享源目标词汇表,包含大约37000个标记。对于英法语言,我们使用了规模显著更大的WMT 2014年英法数据集,其中包含了3600万个句子,并将标记划分为一个32000个词片词汇表[38]。根据近似的序列长度,我们将句子对分批处理。每个训练批次包含一组句子对,大约包含25000个源标记和25000个目标标记。

5.2 Hardware and Schedule

我们使用8个NVIDIA P100 GPU在一台计算机上训练了我们的模型。对于使用本文中所述超参数的基础模型,每个培训步骤约需要0.4秒。我们总共训练基础模型100,000个步骤或12个小时。对于我们的大模型(表3中底行所述),步骤时间为1.0秒。大模型训练了300,000个步骤(3.5天)。

5.3 optimizer

我们采用 Adam 优化器[20],β1=0.9,β2=0.98,和 ε=10-9。我们根据以下公式随着训练的进行调整学习率:
在这里插入图片描述
这意味着在前4000个训练步骤中,将学习率线性增加,之后则以步数的倒数平方根成比例地减少。在本研究中,采用了warmup_steps = 4000。

5.4 Regularization

我们在模型训练中使用了三种正则化方法:

残差失效率 我们在每个子层的输出上应用失效率[33],在它被添加到子层输入并进行标准化之前。此外,我们在编码器和解码器堆栈中的嵌入和位置编码的总和上应用失效率。对于基本模型,我们使用 P d r o p = 0.1 P_{drop} = 0.1 Pdrop=0.1的速率。
在这里插入图片描述
标签平滑:在训练过程中,我们采用了标签平滑技术,其值为$\epsilon_{ls} = 0.1 $。这种技术对困惑度造成了一定影响,因为模型学会了更加不确定,但是它能够提高准确率和BLEU得分。

6. 结果

6.1 机器翻译

在WMT 2014英语到德语的翻译任务中,大型Transformer模型(表2中的Transformer(big))比以前报告的最佳模型(包括集成模型)的BLEU得分高出超过2.0,创造了28.4的新的最先进的BLEU得分。该模型的配置列在表3的底部行中。8个P100 GPU上的训练耗时3.5天。我们的基本模型甚至在训练成本远低于任何竞争模型的情况下就能超越所有以前发布的模型和集成模型。

在WMT 2014英法翻译任务中,我们的大型模型取得了41.0的BLEU分数,胜过所有此前公开发表的单一模型,并且训练成本不到此前最先进模型的四分之一。英-法转换器(大型)模型中使用的dropout率为Pdrop = 0.1,而非0.3。

对于基础模型,我们使用了一个通过平均最后5个时间间隔为10分钟的检查点得出的模型。对于大型模型,我们平均了最后20个检查点。我们采用了Beam Search算法,将beam size设为4,长度惩罚参数alpha为0.6 [38]。这些超参数是在开发集上进行实验后选择的。在推理阶段,我们将最大输出长度设置为输入长度+50,但在可能的情况下提前终止 [38]。

表2总结了我们的结果,并将我们的翻译质量和训练成本与文献中其他模型体系结构进行了比较。我们通过将训练时间、使用的GPU数量以及每个GPU的持续单精度浮点容量的估计乘以来估计训练模型所使用的浮点运算次数。

6.2 模型变量

为评估Transformer中不同组件的重要性,我们通过不同方式改变基础模型,并测量其在英德翻译的新闻测试2013年发展数据上的性能指标变化。我们使用了前文所述的束搜索,并且没有进行检查点平均。我们在表3中呈现了这些结果。

在表3标记(A)中,我们变化了注意头的数量以及注意力键和值的尺寸,同时保持计算量不变,正如3.2.2小节所述。虽然单头注意力比最佳设置差0.9 BLEU,但太多的注意力头也会导致质量的下降。

表3:Transformers架构的变化。未列出的数值与基本模型相同。所有度量指标均基于英语到德语的翻译开发集newstest2013。列出的困惑度是基于我们的字节对编码的每个单词片段,并且不应与每个单词的困惑度进行比较。

在这里插入图片描述
表4:Transformer模型在英语短语结构句法分析方面具有良好的推广能力。

在这里插入图片描述
在表3的(B)行中,我们观察到降低注意力键大小dk会损害模型质量。这表明确定兼容性并不容易,比点积更复杂的兼容性函数可能会更有益。我们进一步观察到在(C)和(D)行中,较大的模型如预期的那样更好,并且dropout非常有助于避免过拟合。 在(E)行中,我们将正弦位置编码替换为学习的位置嵌入[9],并观察到与基础模型几乎相同的结果。

6.3 英语成分句法分析

为了评估Transformer是否能够推广到其他任务,我们在英语成分分析上进行了实验。这项任务提出了特定的挑战:输出受到强烈的结构约束,并且明显比输入更长。此外,循环神经网络序列到序列模型在小数据范围内无法达到最先进的结果。

我们基于普林斯顿树库中的华尔街日报部分,包含约 4 万个训练句子,训练了一个 4 层 dmodel = 1024 的 transformer 模型。此外,我们还采用了半监督的方法,在较大的高置信度和 BerkleyParser 语料库中,使用了约 1700 万个句子。对于只基于华尔街日报训练句子的模型,我们使用了包含 16K 个标记的词汇表;对于半监督训练模型,我们则使用了包含 32K 个标记的词汇表。

我们仅执行了少量的实验,以在22部分开发集上选择辍学率、注意力和残差(第5.4节)、学习率和beam大小,其他所有参数均保持不变,与英语到德语基础翻译模型一致。在推断期间,我们将最大输出长度增加到输入长度+300。对于仅使用WSJ和半监督设置,我们使用21的beam大小和α = 0.3。

我们在表4中的结果显示,尽管缺乏特定任务的调整,我们的模型表现出令人惊讶的良好表现,在除了递归神经网络语法[8]之外,比所有以前报告的模型更出色。

与RNN序列到序列模型相比,Transformer 甚至在仅基于40000个句子的WSJ训练集进行训练时,也能胜过BerkeleyParser 。

7. 结论

在这项工作中,我们提出了Transformer,这是第一个完全基于注意力机制的序列转换模型,用多头自注意力替换了在编码器-解码器架构中最常用的递归层。

对于翻译任务,相对于基于递归或卷积层的架构,Transformer的训练速度能够显著加快。在WMT2014英德和WMT2014英法翻译任务上,我们均取得了全新的最佳效果。在前一项任务中,我们的最佳模型甚至超过了所有之前报道的集成模型。我们对基于注意力机制的模型的未来发展感到兴奋,并计划将其应用于其他任务。

我们计划将Transformer扩展到涉及文本以外的输入和输出形式的问题,并研究局部、受限的注意力机制,以有效地处理大的输入和输出,例如图像、音频和视频内容。使生成变得不那么顺序化也是我们的另一个研究目标。

我们使用的用于训练和评估模型的代码可在https://github.com/ tensorflow/tensor2tensor上获得。

致谢:我们感谢Nal Kalchbrenner和Stephan Gouws对我们的工作的有益评论、改正和启发。

提问

1. 顺序计算的基本限制是什么

顺序计算的基本限制是无法在训练示例内进行并行化,尤其当序列长度较长时,内存限制会限制跨示例进行批处理。递归模型通常将计算沿着输入和输出序列的符号位置进行分解。将这些位置与计算时间的步骤对齐,它们生成一系列隐藏状态 h t h_t ht,作为前一个隐藏状态 h t − 1 h_{t−1} ht1和位置t处的输入的函数。这种固有的顺序性质排除了训练示例内的并行化,这在较长的序列长度下尤为关键。注意机制已成为在各种任务中引人注目的序列建模和转换模型的重要组成部分,允许对依赖项进行建模,而不考虑它们在输入或输出序列中的距离。然而,在除了一些情况之外,这些注意机制与递归网络一起使用。

2. 本文的Transformer模型结构是什么

Transformer模型结构是一种基于注意力机制的神经网络,完全摒弃了RNN和卷积网络,因此比传统模型更容易实现并行计算和训练。Transformer模型包含多个编码器和解码器,其中编码器和解码器都包含自注意力机制和编码-解码注意力机制,并通过残差连接相互连接。Transformer模型在机器翻译等任务中表现出色,取得了较高的BLEU分数,并能在短时间内训练出高质量模型,同时泛化能力强,适用于其他任务

3. 残差链接是如何实现的

在Transformer模型中,编码器的残差链接通过在每个子层中添加残差连接和层归一化来实现。具体而言,每个子层的输入是残差连接的输出加上该子层的输入,并进行归一化。然后,在每个子层输出上再应用一个残差连接。这种残差连接的作用在于加快模型的训练。当然,解码器的残差连接同样通过这种方式实现。

4. 缩放点积注意力是什么,如何实现,有何效果

缩放点积注意力是一种用于实现自注意力机制的技术。在Transformer模型中,多头自注意力层的输入包括来自前一层的查询、键和值,将它们输入到缩放点积注意力函数中进行计算。这个函数中的输入会被分成多个向量,称为多头,然后并行地进行计算。最终,对于每个多头,输出被再次连接起来,传递到下一层。这种方法仅使用点积操作,而且通过增加一个缩放因子,可避免点积结果过大。
通过实验证明,缩放点积注意力在自然语言处理任务中具有优秀的效果。在WMT 2014的英德翻译任务上,使用Transformer模型,最高BLEU得分达到了28.4,超越了现有的最佳结果。并且,在WMT 2014的英法翻译任务上,Transformer模型在单机器训练时,达到最佳的BLEU得分,为41.8,训练时间极大地缩短。此外,Transformer模型对于其他任务也具有很好的通用性,比如英文句法分析任务。
总的来说,缩放点积注意力是一种高效并行的自注意力机制,通过它能够学习到全局相关性,在自然语言处理任务中有比较好的应用效果。

5. 多头注意力相比于缩放点积注意力有什么提升

  1. 提高了模型的并行性,使得更多的计算可以同时进行,从而提升了训练速度和效率。
  2. 可以更好地捕捉到不同发现细节和特征之间的关系,从而提高了模型的表现力和性能。
  3. 可以更好地适应不同任务和数据,从而具有更广泛的应用范围和灵活性。多头注意力已经被成功地应用于自然语言处理领域,并被证明是一种有效的注意力机制。

6. Embeddings一词如何理解

嵌入表示是一种将高维度符号化数据转换成低维度向量的方法。这些向量可以被用于机器学习任务,例如分类和聚类。这种表示方法被广泛运用于自然语言处理(NLP)和计算机视觉领域。在NLP中,嵌入表示通常用于单词或短语的表示,目的是使它们更易于用于文本处理任务。计算机视觉领域中,嵌入表示被用于图像和视频的表示,以及人脸识别和物体识别的任务。嵌入表示的学习通常使用神经网络模型和无监督学习方法。

7. 什么是Transformer

Transformer是一种模型架构,它完全排除了RNN和卷积,而是完全依靠自注意力机制建立输入和输出之间的全局依赖关系。相比之下,循环模型会沿着输入和输出序列的符号位置分解计算,这种序列化的特性会限制训练样本内的并行计算,使得在较长的序列长度下,内存限制会限制跨样本进行批处理。自注意力机制已经成为各种任务中引人注目的序列建模和传导模型的重要组成部分,允许对依赖关系进行建模而不考虑它们在输入或输出序列中的距离。在Transformer中,对两个任意的输入或输出位置进行信号相关所需的操作次数是一个常数,因此可以在很大程度上实现并行处理。Transformers可以用非常短的训练时间和最少的硬件资源来达到最新的机器翻译性能表现。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/633938.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

单链表OJ题:LeetCode--142.环形链表Ⅱ(判断第一次入环的节点)

朋友们、伙计们&#xff0c;我们又见面了&#xff0c;本期来给大家解读一下LeetCode中第142道单链表OJ题&#xff0c;如果看完之后对你有一定的启发&#xff0c;那么请留下你的三连&#xff0c;祝大家心想事成&#xff01; 数据结构与算法专栏&#xff1a;数据结构与算法 个 人…

【网页设计】第 1 课 - 了解网页设计

欢迎来到博主 Apeiron 的博客&#xff0c;祝您旅程愉快 &#xff01; 时止则止&#xff0c;时行则行。动静不失其时&#xff0c;其道光明。 目录 1、缘起 2、了解网页设计 2.1、网页设计 2.2、网站结构 2.3、网站分类 2.4、页面鉴赏 3、总结 1、缘起 前段时间学习完了前…

OpenCV 图像与视频的基础操作

文章目录 引言创建和显示窗口如何通过 OpenCV 加载图片问题加载图片存在的问题如何通过 openCV 保存图片&#xff08;保存图片&#xff09;如何通过 OpenCV 保存图片如何利用 OpenCV 从摄像头采集视频&#xff08;读取视频文件&#xff09;如何从多媒体文件中读取视频帧&#x…

52、基于51单片机脉搏心率报警LCD 1602显示系统设计(程序+原理图+PCB图+Proteus仿真+参考论文+开题报告+任务书+外文文献+元器件清单等)

摘 要 脉搏心率测量仪在我们的日常生活中已经得到了非常广泛的应用,通过观测脉搏信号&#xff0c;可以对人体的健康进行检查&#xff0c;通常被用于保健中心和医院。为了提高脉搏测量仪的简便性和精确度&#xff0c;本课题设计了一种基于51单片机的脉搏测量仪。系统以51单片机…

C++设计模式 - 创建型模式之工厂模式

文章目录 C设计模式 - 创建型模式之工厂模式接口和针对接口编程 1. 简单工厂模式适用场合UML代码示例 2. 工厂方法模式适用场合UML代码示例 3. 抽象工厂模式适用场合UML代码示例 总结 C设计模式 - 创建型模式之工厂模式 工厂模式属于创建型模式&#xff0c;大致可以分为三类&a…

【Linux】信号量(基于环形队列的生产消费模型)

文章目录 POSIX信号量一、什么是信号量二、信号量接口1.初始化信号量2.销毁信号量3.申请信号量&#xff08;等待信号量&#xff09;4.释放信号量&#xff08;发布信号量&#xff09; 基于环形队列的生产消费模型一、结构介绍二、理论讲解三、代码实现 总结 POSIX信号量 POSIX信…

C语言之操作符详解

本章重点 1. 各种操作符的介绍 2. 表达式求值 给大家提到一些操作符&#xff0c;下面我们来给大家详细介绍 首先看算术操作符&#xff0c;其他几个都没什么可讲的我们来重点看一下/&#xff08;除法&#xff09; 整数除法&#xff08;除号的两端都是整数&#xff09; 浮点…

【漏洞复现】Apache RocketMQ 命令注入漏洞(CVE-2023-33246)

文章目录 前言声明一、漏洞描述二、漏洞危害三、影响版本四、环境搭建五、漏洞复现六、修复建议 前言 RocketMQ 是阿里巴巴在2012年开发的分布式消息中间件&#xff0c;专为万亿级超大规模的消息处理而设计&#xff0c;具有高吞吐量、低延迟、海量堆积、顺序收发等特点。同时它…

Shell脚本查询进程并kill进程(集群版)

记录&#xff1a;454 场景&#xff1a;使用Shell脚本查询进程并kill进程。使用Shell脚本远程执行脚本查询进程并kill进程。 版本&#xff1a;CentOS Linux release 7.9.2009。 1.使用Shell脚本查询进程并kill进程 1.1脚本 脚本名称&#xff1a;zk-kill_pid.sh 脚本内容&a…

从ROS1到ROS2无人机编程实战指南

亲爱的读者们&#xff0c;我今天非常荣幸地向大家推荐一本本人的全新力作——《从ROS1到ROS2无人机编程实战指南》。这本书站在初学者的角度&#xff0c;从入门到进阶&#xff0c;再到实战&#xff0c;循序渐进&#xff0c;是学习ROS1和ROS2的最佳选择。如今已在全国范围内上市…

Java spring boot 全解Camunda 7,从 0 到 1 构建工作流平台——第一节:各个开源框架对比

目录 1. Camunda 介绍2. Camunda 选型说明2.1 osworkflow2.2 jbpm2.3 ActivitiActiviti介绍各个版本的优缺点 2.4 flowable2.5 camundacamunda介绍主流版本介绍 2.6 n8n.io2.7 为什么选 camunda ? camunda7.x 还是 camunda 8.x &#xff1f;为什么选 camunda&#xff1f;camun…

碳排放预测模型 | Python实现基于机器学习回归分析的碳排放预测模型——数据可视化和探索

文章目录 效果一览文章概述研究内容环境准备源码设计学习总结参考资料效果一览 文章概述 碳排放预测模型 | Python实现基于机器回归分析的碳排放预测模型——数据可视化和探索 目标是测试所选特征对分析的重要性,检测异常值的存在并准备数据以供进一步分析。 </

Netty实战(十二)

预置的ChannelHandler和编解码器&#xff08;二&#xff09;HTTPS、WebSocket的添加使用和大型数据写入以及几种常见的序列化 一、基于Netty的HTTPS程序1.2 使用HTTPS2.3 WebSocket 二、空闲连接和超时三、 解码基于分隔符的协议和基于长度的协议3.1 基于分割符的协议3.2 基于长…

策 略 模 式「指 鼠 为 鸭」

前言 大家好&#xff0c;我是 god23bin&#xff0c;今天我们来介绍下设计模式中的一个重要的设计模式——策略模式。 当涉及到某个行为或算法有多个变体时&#xff0c;策略模式是一种常见的设计模式。它允许在运行时选择使用不同的策略&#xff0c;而无需修改现有代码。 现在…

OneFormer:规则通用图像分割的一个Transformer

文章目录 OneFormer: One Transformer to Rule Universal Image Segmentation摘要本文方法实验结果 OneFormer: One Transformer to Rule Universal Image Segmentation 摘要 通用图像分割并不是一个新概念。过去统一图像分割的尝试包括场景解析、全景分割&#xff0c;以及最…

【工具】SecureCR-8.5下载、安装激活和使用教程(包含常用设置)

目录 一、安装包下载 二、安装教程 三、激活操作 四、使用教程 五、常用设置 一、安装包下载 SecureCRT8.5安装包&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1yy677I99ln_3evoHc5dMXg 提取码&#xff1a;9tyj 二、安装教程 1. 解压、双击进行安装 2. 安装进…

【LeetCode】136. 只出现一次的数 python

目录 题目描述 第一次刷题 第二次刷题 异或运算的规则 题目描述 给你一个 非空 整数数组 nums &#xff0c;除了某个元素只出现一次以外&#xff0c;其余每个元素均出现两次。找出那个只出现了一次的元素。 你必须设计并实现线性时间复杂度的算法来解决此问题&#xff0c;…

[LeetCode周赛复盘] 第 106 场双周赛20230611

[LeetCode周赛复盘] 第 106 场双周赛20230611 一、本周周赛总结6461. 判断一个数是否迷人1. 题目描述2. 思路分析3. 代码实现 6425. 找到最长的半重复子字符串1. 题目描述2. 思路分析3. 代码实现 6426. 移动机器人1. 题目描述2. 思路分析3. 代码实现 6463. 找到矩阵中的好子集…

DHCP是什么?它有什么作用?其工作模式?工作原理?

目录 一、DHCP是什么&#xff1f;二、DHCP的作用&#xff1f;1. 在没有DHCP服务的网络中2. 在有DHCP服务的网络中 三、DHCP的工作模式简介四、DHCP的工作原理五、参考资料 一、DHCP是什么&#xff1f; DHCP是动态主机配置协议&#xff08;Dynamic Host Configuration Protocol…

Vue 封装ajax请求[接口]函数

在Vue项目开发当中&#xff0c;当有了后端提供的数据接口之后呢&#xff0c;就需要来为接口定义接口的请求函数&#xff0c;那么在去定义接口函数之前可以先来封装一个ajax请求函数&#xff1b;可能有的初学者在之前的一些篇目当中看到这个vue发起数据请求的不是使用axios的吗&…