Sequence to Sequence Learning with Neural Networks
Abstract:DNN可以在有大量标记训练集下表现很好,但是无法处理用于序列映射到序列。在本文中,我们提出了一种端到端的序列训练方法,可以对序列结构做最小的假设。我们的方法使用了多层LSTM将输入序列映射成一个固定维度的向量,然后用另一个深度LSTM从向量中解码出目标序列。
1 Introduction
1)DNN功能强大:DNN在语音识别和视觉目标检测等困难领域都有很好的表现。DNN功能强大,可以执行任意数量的并行计算。只要有足够的标记训练集来指定网络参数,就可以用监督反向传播来训练大型DNN。因此,如果存在一个参数设置能使大型DNN网络能获得良好结果,那么监督反向传播将找到这些参数并解决这个问题
2)DNN'只能用于输入和输出可以用固定维度进行编码的问题:这是一个重要的限制,因为很多重要问题最好用一些未知长度的序列表示。比如语音识别和机器翻译是顺序问题。问答系统也类似。
3)本文使用一种LSTM的结构来解决一般的seq到seq的问题:一个LSTM用来读取输入序列,一次一个时间步,用来获得大的固定维度向量表示;另一个LSTM从向量中提取输出序列。第二个LSTM实质上是循环神经网络模型,只是它的输入序列是有条件的。
4)为解决一般的seq到seq的问题,已有很多相关的尝试:略
5)此结构可以很好地处理长句子:尽管之前有研究者也采用过相关结构,但是很难处理长句子。技巧在于LSTM反向读取输入句子,因为这样做会在数据中引入许多短期依赖关系,从而使优化问题更容易。因此,SDG可以学到不再受长句子困扰的LSTM。将原句中的单词颠倒过来的简单技巧是对这项工作最关键的科学贡献之一。
6)LSTM的有用属性是它学会了将可变长度的输入句子映射到固定向量表示。
7)BLEU是一种用于评估从一种自然语言到另一种自然语言的机器翻译的质量的算法。
8)SMT,统计