深度之眼Paper带读笔记NLP.17:GNMT

2024-03-14 05:30

本文主要是介绍深度之眼Paper带读笔记NLP.17:GNMT,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 前言
  • 第一课 论文导读
    • 神经机器翻译简介
    • 神经机器翻译相关方法(之前有,看带读15课)
      • 多层LSTM模型
      • Attention
      • 处理OOV词
    • 前期知识储备
  • 第二课 论文精读
    • 论文整体框架
    • 模型
      • 残差连接
      • 双向LSTM
      • 束搜索
    • 实验和结果
      • 数据集
      • 实验结果
    • 讨论和总结

前言

Google’s Neural Machine Translation System:Bridging the Gap between Human and Machine Translation
谷歌的神经机器翻译系统
作者:Yonghui Wu et al.
单位:Google
发表会议及时间:2016
在线LaTeX公式编辑器

a. 神经机器翻译的概念
神经机器翻译就是通过端对端的神经网络使得机器能够自动将一种语言的句子翻译成另外一种语言的句子。
b. 三种神经机器翻译模型
了解基于多层LSTM、attention、处理OOV词的三种神经机器翻译模型。
c. 了解Seq2Seq模型
当前的神经机器翻译模型都是基于端对端的Seq2Seq结果,包含一个Encoder和一个Decoder,Encoder将源语言压缩成一个向量,而Decoder利用源语言压缩得到的向量生成目标句子。
d. 谷歌的神经机器翻译系统
理解谷歌神经机器翻译系统的细节,包括模型的总体结构,attention,残差连接,底层的双向LSTM以及改进的Beam Search等。
e. 谷歌神经机器翻译系统实验结果
深入理解论文突出的谷歌神经机器系统的实验结果。

第一课 论文导读

神经机器翻译简介

神经机器翻译:通过端对端的神经网络模型将一种语言的句子翻译成另外一种语言。
意义:解决人与人之前的交流问题。
在这里插入图片描述

神经机器翻译相关方法(之前有,看带读15课)

多层LSTM模型

输入逆序。
在这里插入图片描述

Attention

来自之前读过的:Neural Machine Translation by Jointly Learning to Align and Translate
Encoder:单层双向LSTM。(就是下图中下面两层方框)
Decoder:
对于输出:
p ( y i ) = g ( y i − 1 , s i , c i ) p(y_i)=g(y_{i-1},s_i,c_i) p(yi)=g(yi1,si,ci)
对于 c i c_i ci
c i = ∑ j = 1 T x a i j h j , a i j = e x p ( e i j ) ∑ k = 1 T x e x p ( e i k ) c_i=\sum_{j=1}^{T_x}a_{ij}h_j,a_{ij}=\frac{exp(e_{ij})}{\sum_{k=1}^{T_x}exp(e_{ik})} ci=j=1Txaijhj,aij=k=1Txexp(eik)exp(eij)
w h e r e e i j = a ( s j − 1 , h j ) where \space e_{ij}=a(s_{j-1},h_j) where eij=a(sj1,hj)

处理OOV词

OOV词就是out-of-vocabulary词,文中提出在翻译之后,对于翻译结果中的unk词找到源语言句子中的对应词,然后直接将源语言中对应unk词的词用词典翻译。
在这里插入图片描述
REF:Addressing the Rare Word Problem in Neural Machine Translation

前期知识储备

了解Seq2Seq模型
·本文讲的谷歌机器翻译模型就是基于Seq2Seq模型,Seq2Seq模型有一个Encoder和一个Decoder,可以参考:
https://zhuanlan.zhihu.com/p/57155059

第二课 论文精读

论文整体框架

这个论文非常长长长长的(23 pages)
摘要
1.介绍
2.相关工作
3.模型
4.词分割方法(如何处理OOV)
5.目标函数
6&7.加速推理&解码器
8&9.实验结果&结论

模型

模型分别由8层encoder和8层decoder组成
在这里插入图片描述
先看左边的encoder,最下面两层是双向LSTM(就是GPU1和GPU2对应的那里),后面每层都是单向的LSTM。最后的结果用于最后的Attention。Attention是单隐层的感知机(中间蓝色部分),就是一个隐层一个输出层。然后接上decoder中的y1到y3得到的结果用于后面的每一层。
s t = A t t e n t i o n F u n c t i o n ( y t − 1 , x t ) , ∀ t , 1 ≤ t ≤ M s_t=AttentionFunction(y_{t-1},x_t),\forall t,1≤t≤M st=AttentionFunction(yt1,xt),t,1tM
p t = e x p ( s t ) ∑ t = 1 M e x p ( s t ) , ∀ t , 1 ≤ t ≤ M p_t=\frac{exp(s_t)}{\sum_{t=1}^Mexp(s_t)},\forall t,1≤t≤M pt=t=1Mexp(st)exp(st),t,1tM
a i = ∑ t = 1 M p t ⋅ x t a_i=\sum_{t=1}^Mp_t\cdot x_t ai=t=1Mptxt

残差连接

由于层比较多,为了防止梯度消失,加入了残差连接模块
在这里插入图片描述
c t i , m t i = L S T M i ( c t − 1 i , m t − 1 i , x t − 1 i ; W i ) c_t^i,m_t^i=LSTM_i(c^i_{t-1},m^i_{t-1},x^i_{t-1};W^i) cti,mti=LSTMi(ct1i,mt1i,xt1i;Wi)
x t i = m t i x_t^i=m_t^i xti=mti
c t i + 1 , m t i + 1 = L S T M i + 1 ( c t − 1 i + 1 , m t − 1 i + 1 ; W i + 1 ) c_t^{i+1},m_t^{i+1}=LSTM_{i+1}(c_{t-1}^{i+1},m_{t-1}^{i+1};W^{i+1}) cti+1,mti+1=LSTMi+1(ct1i+1,mt1i+1;Wi+1)
其中i代表第几层, x t i x_t^i xti是t时刻 L S T M i LSTM_i LSTMi的输入, m t i m_t^i mti c t i c_t^i cti分别是t时刻 L S T M i LSTM_i LSTMi隐层状态和记忆单元状态,加入了残差连接后,上面的公式变成了:
c t i , m t i = L S T M i ( c t − 1 i , m t − 1 i , x t − 1 i ; W i ) c_t^i,m_t^i=LSTM_i(c^i_{t-1},m^i_{t-1},x^i_{t-1};W^i) cti,mti=LSTMi(ct1i,mt1i,xt1i;Wi)
x t i = m t i + x t i − 1 x_t^i=m_t^i+x_t^{i-1} xti=mti+xti1
c t i + 1 , m t i + 1 = L S T M i + 1 ( c t − 1 i + 1 , m t − 1 i + 1 ; W i + 1 ) c_t^{i+1},m_t^{i+1}=LSTM_{i+1}(c_{t-1}^{i+1},m_{t-1}^{i+1};W^{i+1}) cti+1,mti+1=LSTMi+1(ct1i+1,mt1i+1;Wi+1)
这样梯度就可以不通过LSTM直接从前一层传到后一层。

双向LSTM

一个LSTM是正向,一个LSTM是反向的,然后把他们的结果进行concat,双向LSTM计算量是比较大的,所以没有在所有后面的模型结构中使用,而是在第一层使用了。
在这里插入图片描述

束搜索

在这里插入图片描述
其中lp是让模型倾向于长句结果例如:
在这里插入图片描述
cp是在等长结果的情况下,倾向于每个结果与原文的每个词更加匹配的结果,例如:
在这里插入图片描述
两个超参数α和β变化与结果的关系
在这里插入图片描述

实验和结果

数据集

WMT English to French:包含36M英语到法语的双语语料,是机器翻译领域最常用的语料之一。
WMT English to German:包含5M英语到德语的双语语料,机器翻译领域最常用的

实验结果

结果解读老师的mic听得要吐血,自己看文章吧。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

讨论和总结

本篇论文的主要贡献?
本文提出的GNMT使用多种技术大大超越了传统的基于短语的统计翻译模型。
GNMT的优点?
GNMT是使用当时神经机器翻译的集大成者,使用多种神经机器翻译技术大大超越了PBMT(传统基于统计的机器翻译模型)。
后来的改进模型?
后面的改进有改进LSTM,有改进Beam Search,还有词分割等等。
创新点:
A.提出了一种新的端对端神经翻译模型。
B.使用了多种技术使得其成为谷歌翻译的核心技术。
C.在多个数据集上达到了最好结果。

这篇关于深度之眼Paper带读笔记NLP.17:GNMT的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/807338

相关文章

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

基于UE5和ROS2的激光雷达+深度RGBD相机小车的仿真指南(五):Blender锥桶建模

前言 本系列教程旨在使用UE5配置一个具备激光雷达+深度摄像机的仿真小车,并使用通过跨平台的方式进行ROS2和UE5仿真的通讯,达到小车自主导航的目的。本教程默认有ROS2导航及其gazebo仿真相关方面基础,Nav2相关的学习教程可以参考本人的其他博客Nav2代价地图实现和原理–Nav2源码解读之CostMap2D(上)-CSDN博客往期教程: 第一期:基于UE5和ROS2的激光雷达+深度RG

韦季李输入法_输入法和鼠标的深度融合

在数字化输入的新纪元,传统键盘输入方式正悄然进化。以往,面对实体键盘,我们常需目光游离于屏幕与键盘之间,以确认指尖下的精准位置。而屏幕键盘虽直观可见,却常因占据屏幕空间,迫使我们在操作与视野间做出妥协,频繁调整布局以兼顾输入与界面浏览。 幸而,韦季李输入法的横空出世,彻底颠覆了这一现状。它不仅对输入界面进行了革命性的重构,更巧妙地将鼠标这一传统外设融入其中,开创了一种前所未有的交互体验。 想象

论文阅读笔记: Segment Anything

文章目录 Segment Anything摘要引言任务模型数据引擎数据集负责任的人工智能 Segment Anything Model图像编码器提示编码器mask解码器解决歧义损失和训练 Segment Anything 论文地址: https://arxiv.org/abs/2304.02643 代码地址:https://github.com/facebookresear

免费也能高质量!2024年免费录屏软件深度对比评测

我公司因为客户覆盖面广的原因经常会开远程会议,有时候说的内容比较广需要引用多份的数据,我记录起来有一定难度,所以一般都用录屏工具来记录会议内容。这次我们来一起探索有什么免费录屏工具可以提高我们的工作效率吧。 1.福晰录屏大师 链接直达:https://www.foxitsoftware.cn/REC/  录屏软件录屏功能就是本职,这款录屏工具在录屏模式上提供了多种选项,可以选择屏幕录制、窗口

数学建模笔记—— 非线性规划

数学建模笔记—— 非线性规划 非线性规划1. 模型原理1.1 非线性规划的标准型1.2 非线性规划求解的Matlab函数 2. 典型例题3. matlab代码求解3.1 例1 一个简单示例3.2 例2 选址问题1. 第一问 线性规划2. 第二问 非线性规划 非线性规划 非线性规划是一种求解目标函数或约束条件中有一个或几个非线性函数的最优化问题的方法。运筹学的一个重要分支。2

【C++学习笔记 20】C++中的智能指针

智能指针的功能 在上一篇笔记提到了在栈和堆上创建变量的区别,使用new关键字创建变量时,需要搭配delete关键字销毁变量。而智能指针的作用就是调用new分配内存时,不必自己去调用delete,甚至不用调用new。 智能指针实际上就是对原始指针的包装。 unique_ptr 最简单的智能指针,是一种作用域指针,意思是当指针超出该作用域时,会自动调用delete。它名为unique的原因是这个

查看提交历史 —— Git 学习笔记 11

查看提交历史 查看提交历史 不带任何选项的git log-p选项--stat 选项--pretty=oneline选项--pretty=format选项git log常用选项列表参考资料 在提交了若干更新,又或者克隆了某个项目之后,你也许想回顾下提交历史。 完成这个任务最简单而又有效的 工具是 git log 命令。 接下来的例子会用一个用于演示的 simplegit

记录每次更新到仓库 —— Git 学习笔记 10

记录每次更新到仓库 文章目录 文件的状态三个区域检查当前文件状态跟踪新文件取消跟踪(un-tracking)文件重新跟踪(re-tracking)文件暂存已修改文件忽略某些文件查看已暂存和未暂存的修改提交更新跳过暂存区删除文件移动文件参考资料 咱们接着很多天以前的 取得Git仓库 这篇文章继续说。 文件的状态 不管是通过哪种方法,现在我们已经有了一个仓库,并从这个仓