Transformer常见问题与回答总结

Q&A

  1. Transformer为何使用多头注意力机制?(为什么不使用一个头)

    • 多头保证了transformer可以注意到不同子空间的信息,捕捉到更加丰富的特征信息。可以类比CNN中同时使用多个滤波器的作用,直观上讲,多头的注意力有助于网络捕捉到更丰富的特征/信息。
    • 参考:https://www.zhihu.com/question/341222779
  2. Transformer为什么Q和K使用不同的权重矩阵生成,为何不能使用同一个值进行自身的点乘? (注意和第一个问题的区别)

    • 使用Q/K/V不相同可以保证在不同空间进行投影,增强了表达能力,提高了泛化能力。
    • 同时,由softmax函数的性质决定,实质做的是一个soft版本的arg max操作,得到的向量接近一个one-hot向量(接近程度根据这组数的数量级有所不同)。如果令Q=K,那么得到的模型大概率会得到一个类似单位矩阵的attention矩阵,这样self-attention就退化成一个point-wise线性映射。这样至少是违反了设计的初衷。
    • 参考:https://www.zhihu.com/question/319339652
  3. Transformer计算attention的时候为何选择点乘而不是加法?两者计算复杂度和效果上有什么区别?

    • K和Q的点乘是为了得到一个attention score 矩阵,用来对V进行提纯。K和Q使用了不同的W_k, W_Q来计算,可以理解为是在不同空间上的投影。正因为 有了这种不同空间的投影,增加了表达能力,这样计算得到的attention score矩阵的泛化能力更高。
    • 为了计算更快。矩阵加法在加法这一块的计算量确实简单,但是作为一个整体计算attention的时候相当于一个隐层,整体计算量和点积相似。在效果上来说,从实验分析,两者的效果和dk相关,dk越大,加法的效果越显著。
  4. 为什么在进行softmax之前需要对attention进行scaled(为什么除以dk的平方根),并使用公式推导进行讲解

    • 这取决于softmax函数的特性,如果softmax内计算的数数量级太大,会输出近似one-hot编码的形式,导致梯度消失的问题,所以需要scale
    • 那么至于为什么需要用维度开根号,假设向量q,k满足各分量独立同分布,均值为0,方差为1,那么qk点积均值为0,方差为dk,从统计学计算,若果让qk点积的方差控制在1,需要将其除以dk的平方根,是的softmax更加平滑
    • 参考:https://www.zhihu.com/question/339723385/answer/782509914
  5. 在计算attention score的时候如何对padding做mask操作?

  6. 为什么在进行多头注意力的时候需要对每个head进行降维?(可以参考上面一个问题)

    • 将原有的高维空间转化为多个低维空间并再最后进行拼接,形成同样维度的输出,借此丰富特性信息
      • 基本结构:Embedding + Position Embedding,Self-Attention,Add + LN,FN,Add + LN
  7. 为何在获取输入词向量之后需要对矩阵乘以embedding size的开方?意义是什么?

    • embedding matrix的初始化方式是xavier init,这种方式的方差是1/embedding size,因此乘以embedding size的开方使得embedding matrix的方差是1,在这个scale下可能更有利于embedding matrix的收敛。
  8. 简单介绍一下Transformer的位置编码?有什么意义和优缺点?

  9. 你还了解哪些关于位置编码的技术,各自的优缺点是什么?(参考上一题)

    • 相对位置编码(RPE)1.在计算attention score和weighted value时各加入一个可训练的表示相对位置的参数。2.在生成多头注意力时,把对key来说将绝对位置转换为相对query的位置3.复数域函数,已知一个词在某个位置的词向量表示,可以计算出它在任何位置的词向量表示。前两个方法是词向量+位置编码,属于亡羊补牢,复数域是生成词向量的时候即生成对应的位置信息。
  10. 简单讲一下Transformer中的残差结构以及意义。

    • 就是ResNet的优点,解决梯度消失
  11. 为什么transformer块使用LayerNorm而不是BatchNorm?LayerNorm 在Transformer的位置是哪里?

    • LN:针对每个样本序列进行Norm,没有样本间的依赖。对一个序列的不同特征维度进行Norm
    • CV使用BN是认为channel维度的信息对cv方面有重要意义,如果对channel维度也归一化会造成不同通道信息一定的损失。而同理nlp领域认为句子长度不一致,并且各个batch的信息没什么关系,因此只考虑句子内信息的归一化,也就是LN。
  12. 简答讲一下BatchNorm技术,以及它的优缺点。

    • 优点:
      • 第一个就是可以解决内部协变量偏移,简单来说训练过程中,各层分布不同,增大了学习难度,BN缓解了这个问题。当然后来也有论文证明BN有作用和这个没关系,而是可以使损失平面更加的平滑,从而加快的收敛速度。
      • 第二个优点就是缓解了梯度饱和问题(如果使用sigmoid激活函数的话),加快收敛。
    • 缺点:
      • 第一个,batch_size较小的时候,效果差。这一点很容易理解。BN的过程,使用 整个batch中样本的均值和方差来模拟全部数据的均值和方差,在batch_size 较小的时候,效果肯定不好。
      • 第二个缺点就是 BN 在RNN中效果比较差。
  13. 简单描述一下Transformer中的前馈神经网络?使用了什么激活函数?相关优缺点?

    • ReLU

      https://github.com/JackHCC/NLP-Bubble/raw/master/image/img/interview/image-20220305132637548.png

  14. Encoder端和Decoder端是如何进行交互的?(在这里可以问一下关于seq2seq的attention知识)

    • Cross Self-Attention,Decoder提供Q,Encoder提供K,V
  15. Decoder阶段的多头自注意力和encoder的多头自注意力有什么区别?(为什么需要decoder自注意力需要进行 sequence mask)

    • 让输入序列只看到过去的信息,不能让他看到未来的信息
  16. Transformer的并行化提现在哪个地方?Decoder端可以做并行化吗?

    • Encoder侧:模块之间是串行的,一个模块计算的结果做为下一个模块的输入,互相之前有依赖关系。从每个模块的角度来说,注意力层和前馈神经层这两个子模块单独来看都是可以并行的,不同单词之间是没有依赖关系的。
    • Decode引入sequence mask就是为了并行化训练,Decoder推理过程没有并行,只能一个一个的解码,很类似于RNN,这个时刻的输入依赖于上一个时刻的输出。
  17. 简单描述一下wordpiece model 和 byte pair encoding,有实际应用过吗?

    • 传统词表示方法无法很好的处理未知或罕见的词汇(OOV问题),传统词tokenization方法不利于模型学习词缀之间的关系”
    • BPE(字节对编码)或二元编码是一种简单的数据压缩形式,其中最常见的一对连续字节数据被替换为该数据中不存在的字节。后期使用时需要一个替换表来重建原始数据。
    • 优点:可以有效地平衡词汇表大小和步数(编码句子所需的token次数)。
    • 缺点:基于贪婪和确定的符号替换,不能提供带概率的多个分片结果。
  18. Transformer训练的时候学习率是如何设定的?Dropout是如何设定的,位置在哪里?Dropout 在测试的需要有什么需要注意的吗?

    • Dropout测试的时候记得对输入整体呈上dropout的比率
  19. 引申一个关于bert问题,bert的mask为何不学习transformer在attention处进行屏蔽score的技巧?

    • BERT和transformer的目标不一致,bert是语言的预训练模型,需要充分考虑上下文的关系,而transformer主要考虑句子中第i个元素与前i-1个元素的关系。
  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Transformer一种用于自然语言处理和机器翻译等任务的深度学习模型。以下是一些关于 Transformer常见问题: 1. Transformer 是什么?为什么它被广泛应用于自然语言处理领域? Transformer 是一种基于自注意力机制的神经网络架构。它通过使用注意力机制来捕捉输入序列的上下文信息,从而在处理自然语言时能够更好地理解上下文关系,并且能够并行化计算,加快训练和推理速度。 2. Transformer 的结构是怎样的? Transformer 主要由编码器和解码器组成。编码器将输入序列转换为一系列的隐藏表示,而解码器则通过对编码器输出进行自注意力操作来生成输出序列。 3. Transformer 的自注意力机制是什么意思? 自注意力机制允许模型对输入序列的不同位置进行加权关注,从而能够更好地捕捉到序列不同位置之间的依赖关系。在自注意力机制,每个单词都会计算一个权重,该权重表示该单词与其他单词之间的相关性。 4. Transformer 相对于传统的循环神经网络有什么优势? 相较于传统的循环神经网络(如 LSTM 或 GRU),Transformer 具有以下优势: - 并行化计算:Transformer 可以同时处理输入序列的所有位置,而不需要按顺序逐个计算。 - 长期依赖建模:由于自注意力机制的引入,Transformer 能够更好地捕捉到序列不同位置之间的长期依赖关系。 - 更好的表示能力:Transformer 的多头注意力机制允许模型在不同的注意力空间上进行学习,从而提高了模型的表示能力。 5. Transformer 的应用领域有哪些? Transformer 在自然语言处理领域有广泛应用,如机器翻译、文本摘要、对话系统等。此外,Transformer 也被用于图像处理领域,如图像生成和图像分类等任务。 这些是一些关于 Transformer常见问题,希望能对你有所帮助!如果有更多问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JackHCC

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值