Current statistical machine translation systems
源语言:法语
目标语言:英语
概率公式(利用贝叶斯定理):
data:image/s3,"s3://crabby-images/a13eb/a13eb47ee7c64f543fa3c2ba24bcab41fc171fd6" alt="这里写图片描述"
在平行语料库(parallel corpora)上训练翻译模型p(f|e)
在英语语料库上训练语言模型p(e)
data:image/s3,"s3://crabby-images/d57bb/d57bbb5cc08dff1f0a7ec24fcba646820ab57e09" alt="这里写图片描述"
Step1: Alignment
目标:将源语言中的单词或者短语匹配到正确的目标语言中的单词或者短语
data:image/s3,"s3://crabby-images/6d9fe/6d9fe7a94f56ecb590ac9e290089c508e8c5a397" alt="这里写图片描述"
假如匹配好了单词和短语,那么又如何给这些单词和短语重新排序呢?
data:image/s3,"s3://crabby-images/39c17/39c17d75b9271c31f752acb5afc139704861b399" alt="这里写图片描述"
After many steps
每个源语言中的单词或者短语,在目标语言中都有不止一个相匹配的单词或者短语:
data:image/s3,"s3://crabby-images/47376/47376906adf8a5257813008ec91c1943ebe204f2" alt="这里写图片描述"
Decode: Search for best of many hypotheses
data:image/s3,"s3://crabby-images/d2a67/d2a67da6fcaa0db36d667080b8453b06ab839d49" alt="这里写图片描述"
TradiBonal MT(Machine Translation)
直接跳过非常多的细节部分
需要非常多的人工处理特征信息
非常复杂的系统
Deep learning to the rescue! … ?
也许我们能直接使用RNN做机器翻译
data:image/s3,"s3://crabby-images/cf430/cf4303ec6e44ae500af96e7acbdf12228cd615fd" alt="这里写图片描述"
MT with RNNs – Simplest Model
data:image/s3,"s3://crabby-images/8dc7e/8dc7ec140edaf49774a9d6e593a5217afb6e8097" alt="这里写图片描述"
最小化基于源语言,对应的目标语言中的词的交叉熵:
data:image/s3,"s3://crabby-images/27148/27148071e860fae4790007de506a0deb3031581c" alt="这里写图片描述"
然而并没有这么的简单:)
RNN Translation Model Extensions
1)decoding和encoding部分,训练得到的RNN的Weeights是不一样的:
data:image/s3,"s3://crabby-images/81ad4/81ad41398c937dbcbbc78a6e13da128cc8717699" alt="这里写图片描述"
data:image/s3,"s3://crabby-images/4f8ac/4f8ac287c7a2bfd429dd48a6d9bb82a49a29b468" alt="这里写图片描述"
2)在解码时,根据下面的三项计算当前的hidden层:
1.之前的hidden层
2.上一个编码器的hidden层:c=hT
3.之前预测得到的词yt-1
data:image/s3,"s3://crabby-images/b814b/b814b0c03ba6fdb80c22fccf13a6ac9e967ffe42" alt="这里写图片描述"
data:image/s3,"s3://crabby-images/7b605/7b605a6b23b62cd516b6d8375dc6ab6eb160b164" alt="这里写图片描述"
对上一幅图更详细的描述
data:image/s3,"s3://crabby-images/92011/92011343f72d369a9db42ead9f4885a161db2833" alt="这里写图片描述"
3)训练多层 stacked/deep RNNs
4)也可训练双向RNN
data:image/s3,"s3://crabby-images/57b26/57b26aef8d9d05a51f5901c085d48fd0fca7405a" alt="这里写图片描述"
5)将输入序列反向后训练,以使得优化更加简单,如:A B C-》X Y换成C B A-》X Y
6)Main Improvement: Better Units。在循环的时候使用更加复杂的hidden units,如Gated Recurrent Units(GRU)
GRUs
标准的RNN直接计算下一个time step的hidden layer:
data:image/s3,"s3://crabby-images/ec65c/ec65c0f99a0b36e9889793a308245ba9a8945f18" alt="这里写图片描述"
而在GRU中,则是先计算一个update gate,update gate是由当前的输入向量以及上一个hidden 层决定:
data:image/s3,"s3://crabby-images/96155/96155371b1c5194a7dd7fb3713ec880121e78a04" alt="这里写图片描述"
再用不同的Weights计算reset gate
data:image/s3,"s3://crabby-images/9cb68/9cb6874638cc910bf94471868728cd7051f2d4b2" alt="这里写图片描述"
由update gate和reset gate的公式可以得到新的记忆内容,如果reset gate接近于0,则忽略之前的记忆单元(隐层单元),只取当前time step的词向量:
data:image/s3,"s3://crabby-images/938d9/938d9ff5ffe229f8d04e11edd51c02dccd3eaf01" alt="这里写图片描述"
最终的time step的记忆单元(隐层单元)公式:
data:image/s3,"s3://crabby-images/08ab4/08ab446c33c27d85d432762438998d6edfb16d69" alt="这里写图片描述"
下面这张图有利于你理解GRU:
data:image/s3,"s3://crabby-images/531f1/531f109c8f63c3bf28e64418ca828f1eb38f384b" alt="这里写图片描述"
GRU intuition
如果reset gate接近于0,则忽略之前hidden层的h。这样做的好处是可以丢弃和后面训练过程无关的信息。
update gate z的作用则是控制之前的部分对当前time step计算结果的影响程度(大小)。如果z接近于1,我们就可以将信息直接copy过来,这样的话有利于避免vanishing gradient。
短期依赖(short term dependences)的reset gate很活跃
长期依赖(long term dependendces)的update gate很活跃
参考图:
data:image/s3,"s3://crabby-images/fdf1f/fdf1ffe51101bbe2e497e0514846797395f5a607" alt="这里写图片描述"
x1*x2对x1的导数如何求?同样使用的是链式法则,不同的是这里是通过模块化(modularization)和自定区划(automatic differentiation)实现的
Long-‐short-‐term-‐memories(LSTMs)
我们可以使传统RNN中的单个Unit(time step)更加复杂
可以在每个time step中添加下图中的几项:
data:image/s3,"s3://crabby-images/084f4/084f4049012dba3d7ebb411ee4dbadca13930613" alt="这里写图片描述"
最终的记忆单元:
data:image/s3,"s3://crabby-images/9bf84/9bf84cebd60aa6e48f3054397179bb7455f68e87" alt="这里写图片描述"
最终得到的hidden层的计算公式:
data:image/s3,"s3://crabby-images/9ee69/9ee699df95c19a1b6b8d0190538801cd28f27712" alt="这里写图片描述"
LSTM详解图:
data:image/s3,"s3://crabby-images/ea286/ea286ef12943ef1c99f1e9255841eabf11212be6" alt="这里写图片描述"
LSTMs are currently very hip!
LSTM是大多数序列标记任务的默认模型
非常的管用,特别是在使模型deeper之后(即每一个hidden层都是由一个内部的深度网络计算得到)
数据越多越管用
但是Deep LSTM和一些传统的MT方法的测试结果相差不大:
data:image/s3,"s3://crabby-images/17360/1736022a6a0d96d545d2e4a508a36bae19fde2c0" alt="这里写图片描述"
Further Improvements: More Gates!
data:image/s3,"s3://crabby-images/8f04b/8f04b60283c97ec9b491dd14384cd86d84377cf1" alt="这里写图片描述"