[译] 理解 LSTM 网络

作者: 朱小虎XiaohuZhu | 来源:发表于2015-08-28 12:36 被阅读306533次

Neil Zhu,简书ID Not_GOD,University AI 创始人 & Chief Scientist,致力于推进世界人工智能化进程。制定并实施 UAI 中长期增长战略和目标,带领团队快速成长为人工智能领域最专业的力量。

作为行业领导者,他和UAI一起在2014年创建了TASA(中国最早的人工智能社团), DL Center(深度学习知识中心全球价值网络),AI growth(行业智库培训)等,为中国的人工智能人才建设输送了大量的血液和养分。此外,他还参与或者举办过各类国际性的人工智能峰会和活动,产生了巨大的影响力,书写了60万字的人工智能精品技术内容,生产翻译了全球第一本深度学习入门书《神经网络与深度学习》,生产的内容被大量的专业垂直公众号和媒体转载与连载。曾经受邀为国内顶尖大学制定人工智能学习规划和教授人工智能前沿课程,均受学生和老师好评。

本文译自 Christopher Olah 的博文

Recurrent Neural Networks

人类并不是每时每刻都从一片空白的大脑开始他们的思考。在你阅读这篇文章时候,你都是基于自己已经拥有的对先前所见词的理解来推断当前词的真实含义。我们不会将所有的东西都全部丢弃,然后用空白的大脑进行思考。我们的思想拥有持久性。

传统的神经网络并不能做到这点,看起来也像是一种巨大的弊端。例如,假设你希望对电影中的每个时间点的时间类型进行分类。传统的神经网络应该很难来处理这个问题——使用电影中先前的事件推断后续的事件。

RNN 解决了这个问题。RNN 是包含循环的网络,允许信息的持久化。

RNN 包含循环

在上面的示例图中,神经网络的模块,A,正在读取某个输入 x_i,并输出一个值 h_i。循环可以使得信息可以从当前步传递到下一步。

这些循环使得 RNN 看起来非常神秘。然而,如果你仔细想想,这样也不比一个正常的神经网络难于理解。RNN 可以被看做是同一神经网络的多次复制,每个神经网络模块会把消息传递给下一个。所以,如果我们将这个循环展开:

展开的 RNN

链式的特征揭示了 RNN 本质上是与序列和列表相关的。他们是对于这类数据的最自然的神经网络架构。

并且 RNN 也已经被人们应用了!在过去几年中,应用 RNN 在语音识别,语言建模,翻译,图片描述等问题上已经取得一定成功,并且这个列表还在增长。我建议大家参考 Andrej Karpathy 的博客文章——The Unreasonable Effectiveness of Recurrent Neural Networks 来看看更丰富有趣的 RNN 的成功应用。

而这些成功应用的关键之处就是 LSTM 的使用,这是一种特别的 RNN,比标准的 RNN 在很多的任务上都表现得更好。几乎所有的令人振奋的关于 RNN 的结果都是通过 LSTM 达到的。这篇博文也会就 LSTM 进行展开。

长期依赖(Long-Term Dependencies)问题

RNN 的关键点之一就是他们可以用来连接先前的信息到当前的任务上,例如使用过去的视频段来推测对当前段的理解。如果 RNN 可以做到这个,他们就变得非常有用。但是真的可以么?答案是,还有很多依赖因素。

有时候,我们仅仅需要知道先前的信息来执行当前的任务。例如,我们有一个语言模型用来基于先前的词来预测下一个词。如果我们试着预测 “the clouds are in the sky” 最后的词,我们并不需要任何其他的上下文 —— 因此下一个词很显然就应该是 sky。在这样的场景中,相关的信息和预测的词位置之间的间隔是非常小的,RNN 可以学会使用先前的信息。

不太长的相关信息和位置间隔

但是同样会有一些更加复杂的场景。假设我们试着去预测“I grew up in France... I speak fluent French”最后的词。当前的信息建议下一个词可能是一种语言的名字,但是如果我们需要弄清楚是什么语言,我们是需要先前提到的离当前位置很远的 France 的上下文的。这说明相关信息和当前预测位置之间的间隔就肯定变得相当的大。

不幸的是,在这个间隔不断增大时,RNN 会丧失学习到连接如此远的信息的能力。

相当长的相关信息和位置间隔

在理论上,RNN 绝对可以处理这样的 长期依赖 问题。人们可以仔细挑选参数来解决这类问题中的最初级形式,但在实践中,RNN 肯定不能够成功学习到这些知识。Bengio, et al. (1994)等人对该问题进行了深入的研究,他们发现一些使训练 RNN 变得非常困难的相当根本的原因。

然而,幸运的是,LSTM 并没有这个问题!

LSTM 网络

Long Short Term 网络—— 一般就叫做 LSTM ——是一种 RNN 特殊的类型,可以学习长期依赖信息。LSTM 由Hochreiter & Schmidhuber (1997)提出,并在近期被Alex Graves进行了改良和推广。在很多问题,LSTM 都取得相当巨大的成功,并得到了广泛的使用。

LSTM 通过刻意的设计来避免长期依赖问题。记住长期的信息在实践中是 LSTM 的默认行为,而非需要付出很大代价才能获得的能力!

所有 RNN 都具有一种重复神经网络模块的链式的形式。在标准的 RNN 中,这个重复的模块只有一个非常简单的结构,例如一个 tanh 层。

标准 RNN 中的重复模块包含单一的层

LSTM 同样是这样的结构,但是重复的模块拥有一个不同的结构。不同于 单一神经网络层,这里是有四个,以一种非常特殊的方式进行交互。

LSTM 中的重复模块包含四个交互的层

不必担心这里的细节。我们会一步一步地剖析 LSTM 解析图。现在,我们先来熟悉一下图中使用的各种元素的图标。

LSTM 中的图标

在上面的图例中,每一条黑线传输着一整个向量,从一个节点的输出到其他节点的输入。粉色的圈代表 pointwise 的操作,诸如向量的和,而黄色的矩阵就是学习到的神经网络层。合在一起的线表示向量的连接,分开的线表示内容被复制,然后分发到不同的位置。

LSTM 的核心思想

LSTM 的关键就是细胞状态,水平线在图上方贯穿运行。

细胞状态类似于传送带。直接在整个链上运行,只有一些少量的线性交互。信息在上面流传保持不变会很容易。

Paste_Image.png

LSTM 有通过精心设计的称作为“门”的结构来去除或者增加信息到细胞状态的能力。门是一种让信息选择式通过的方法。他们包含一个 sigmoid 神经网络层和一个 pointwise 乘法操作。

Paste_Image.png

Sigmoid 层输出 0 到 1 之间的数值,描述每个部分有多少量可以通过。0 代表“不许任何量通过”,1 就指“允许任意量通过”!

LSTM 拥有三个门,来保护和控制细胞状态。

逐步理解 LSTM

在我们 LSTM 中的第一步是决定我们会从细胞状态中丢弃什么信息。这个决定通过一个称为忘记门层完成。该门会读取 h_{t-1}x_t,输出一个在 0 到 1 之间的数值给每个在细胞状态 C_{t-1} 中的数字。1 表示“完全保留”,0 表示“完全舍弃”。

让我们回到语言模型的例子中来基于已经看到的预测下一个词。在这个问题中,细胞状态可能包含当前主语的性别,因此正确的代词可以被选择出来。当我们看到新的主语,我们希望忘记旧的主语

决定丢弃信息
下一步是确定什么样的新信息被存放在细胞状态中。这里包含两个部分。第一,sigmoid 层称 “输入门层” 决定什么值我们将要更新。然后,一个 tanh 层创建一个新的候选值向量,\tilde{C}_t,会被加入到状态中。下一步,我们会讲这两个信息来产生对状态的更新。

在我们语言模型的例子中,我们希望增加新的主语的性别到细胞状态中,来替代旧的需要忘记的主语。

确定更新的信息

现在是更新旧细胞状态的时间了,C_{t-1} 更新为 C_t。前面的步骤已经决定了将会做什么,我们现在就是实际去完成。

我们把旧状态与 f_t 相乘,丢弃掉我们确定需要丢弃的信息。接着加上 i_t * \tilde{C}_t。这就是新的候选值,根据我们决定更新每个状态的程度进行变化。

在语言模型的例子中,这就是我们实际根据前面确定的目标,丢弃旧代词的性别信息并添加新的信息的地方。

更新细胞状态

最终,我们需要确定输出什么值。这个输出将会基于我们的细胞状态,但是也是一个过滤后的版本。首先,我们运行一个 sigmoid 层来确定细胞状态的哪个部分将输出出去。接着,我们把细胞状态通过 tanh 进行处理(得到一个在 -1 到 1 之间的值)并将它和 sigmoid 门的输出相乘,最终我们仅仅会输出我们确定输出的那部分。

在语言模型的例子中,因为他就看到了一个 代词,可能需要输出与一个 动词 相关的信息。例如,可能输出是否代词是单数还是负数,这样如果是动词的话,我们也知道动词需要进行的词形变化。

输出信息

LSTM 的变体

我们到目前为止都还在介绍正常的 LSTM。但是不是所有的 LSTM 都长成一个样子的。实际上,几乎所有包含 LSTM 的论文都采用了微小的变体。差异非常小,但是也值得拿出来讲一下。

其中一个流形的 LSTM 变体,就是由 Gers & Schmidhuber (2000) 提出的,增加了 “peephole connection”。是说,我们让 门层 也会接受细胞状态的输入。

peephole 连接

上面的图例中,我们增加了 peephole 到每个门上,但是许多论文会加入部分的 peephole 而非所有都加。

另一个变体是通过使用 coupled 忘记和输入门。不同于之前是分开确定什么忘记和需要添加什么新的信息,这里是一同做出决定。我们仅仅会当我们将要输入在当前位置时忘记。我们仅仅输入新的值到那些我们已经忘记旧的信息的那些状态 。

coupled 忘记门和输入门
另一个改动较大的变体是 Gated Recurrent Unit (GRU),这是由 Cho, et al. (2014) 提出。它将忘记门和输入门合成了一个单一的 更新门。同样还混合了细胞状态和隐藏状态,和其他一些改动。最终的模型比标准的 LSTM 模型要简单,也是非常流行的变体。 GRU
这里只是部分流行的 LSTM 变体。当然还有很多其他的,如Yao, et al. (2015) 提出的 Depth Gated RNN。还有用一些完全不同的观点来解决长期依赖的问题,如Koutnik, et al. (2014) 提出的 Clockwork RNN。

要问哪个变体是最好的?其中的差异性真的重要吗?Greff, et al. (2015) 给出了流行变体的比较,结论是他们基本上是一样的。Jozefowicz, et al. (2015) 则在超过 1 万种 RNN 架构上进行了测试,发现一些架构在某些任务上也取得了比 LSTM 更好的结果。

Jozefowicz等人论文截图

结论

刚开始,我提到通过 RNN 得到重要的结果。本质上所有这些都可以使用 LSTM 完成。对于大多数任务确实展示了更好的性能!

由于 LSTM 一般是通过一系列的方程表示的,使得 LSTM 有一点令人费解。然而本文中一步一步地解释让这种困惑消除了不少。

LSTM 是我们在 RNN 中获得的重要成功。很自然地,我们也会考虑:哪里会有更加重大的突破呢?在研究人员间普遍的观点是:“Yes! 下一步已经有了——那就是注意力!” 这个想法是让 RNN 的每一步都从更加大的信息集中挑选信息。例如,如果你使用 RNN 来产生一个图片的描述,可能会选择图片的一个部分,根据这部分信息来产生输出的词。实际上,Xu, et al.(2015)已经这么做了——如果你希望深入探索注意力可能这就是一个有趣的起点!还有一些使用注意力的相当振奋人心的研究成果,看起来有更多的东西亟待探索……
注意力也不是 RNN 研究领域中唯一的发展方向。例如,Kalchbrenner, et al. (2015) 提出的 Grid LSTM 看起来也是很有前途。使用生成模型的 RNN,诸如Gregor, et al. (2015) Chung, et al. (2015)Bayer & Osendorfer (2015) 提出的模型同样很有趣。在过去几年中,RNN 的研究已经相当的燃,而研究成果当然也会更加丰富!

致谢

I’m grateful to a number of people for helping me better understand LSTMs, commenting on the visualizations, and providing feedback on this post.
I’m very grateful to my colleagues at Google for their helpful feedback, especially Oriol Vinyals,Greg Corrado, Jon Shlens, Luke Vilnis, and Ilya Sutskever. I’m also thankful to many other friends and colleagues for taking the time to help me, including Dario Amodei, and Jacob Steinhardt. I’m especially thankful to Kyunghyun Cho for extremely thoughtful correspondence about my diagrams.
Before this post, I practiced explaining LSTMs during two seminar series I taught on neural networks. Thanks to everyone who participated in those for their patience with me, and for their feedback.

人工智能时代每个人都将面临挑战,想要了解更多相关知识和实践经验,请关注公众号“UniversityAI”。


UAI 人工智能

相关文章

网友评论

  • 昵称a已被使用:请问Grid LSTM翻译成中文全称应该怎么翻译呢
    朱小虎XiaohuZhu:@昵称a已被使用 正常译作“网格”
  • 970d2d38edbb:首先,作者翻译得很棒!
    不过有个地方有点小问题:我们仅仅会当我们将要输入在当前位置时忘记。我们仅仅输入新的值到那些我们已经忘记旧的信息的那些状态 。
    这句话有点问题。因为后面一句话,原文是when不是where。其实要表达的意思就是,如果没有东西被忘记,那么忘记那边是1,输入就是0,就没有输入。反之同理。所以忘记和输入一定是同时存在的。
  • 水球喵:In such a problem, the cell state might include the gender of the present subject, so that the correct pronouns can be used. When we see a new subject, we want to forget the gender of the old subject.在这个问题中,细胞状态可能包含当前主语的性别,因此正确的代词可以被选择出来。当我们看到新的主语,我们希望忘记旧的主语的性别。
  • a95fdf38fd3e:请问这里的 *乘法 和 点乘法分别表示什么乘法规则?这里的f,i, o计算得到的都是一个向量么?问中的向量间相乘是逐元素相乘么?
    4c97c063d783:同问。
  • 8f5c3ff8c6ff:感谢翻译。我有一个问题,如果是10层隐含层,每层分别为1000,900,800...100个LSTM单元,那么整体的网络结构是怎么样子的呢?
  • de00be845f16:只有我的Latex公式加载不出来吗?
    朱小虎XiaohuZhu:现在支持了
    朱小虎XiaohuZhu:@walktalk latex 简书还不支持吧
    朱小虎XiaohuZhu:@walktalk jianshu好像还不支持 latex,我用 latex 写是为了方便编辑
  • 6670345970f1:这篇文章在介绍LSTM内部的每一部分做的很好,拆开分别介绍,并配上公式,让人思路清晰,不错👍。虽然例子没怎么让人理解
  • 海风自南:这图用什么画的
  • b03f6115f32d:学习了,多谢!
  • smilexuc:好文,啪啪啪鼓掌。
  • fd0c4f86188b:GRU的最后那个公式写错了吧,按照论文中2.3节的公式7,这个式子正好写反了
    fd0c4f86188b:@Not_GOD 哈哈,好的:blush:
    朱小虎XiaohuZhu:被你发现了。确实和原论文的是反过来了。不过这两种实际上几乎是等价的。GRU的作者Cho 也review过这篇文章的。问题不大
  • 6910afe5901c:看了3遍以上,反复看,回味无穷哈
    朱小虎XiaohuZhu:@nosqlcoco 恩,是要多看几遍的。
  • 692baa9d449e:写的太好了,看过很多其他人的介绍都没有理解,在你的讲解下我理解了!太厉害了博主
    朱小虎XiaohuZhu:@回忆_的_小马甲 谢谢,多交流~:smile:
  • fb6c2adf19e0:画图软件是哪个啊
  • eeef4086c7c4:感谢讲解
  • c4fbd798203e:这些图是用什么工具画出来的啊?实在是画得太好了。
    朱小虎XiaohuZhu:@jianshuhu inkscape
  • c075c97cb14e:很好的文章,排版也很好,后面看不懂,还得继续加油
  • 4276488f18ee:讲得太好了,拜服拜服~
  • 赤臂生:前几天参加百度的一个技术分享会,百度称他们对人脸识别已经达到了1亿人认出1个的水平;而我们从1亿中最相似的十个人找出来;连自己父母都不认识;;;问答环节时,我说:如果随机找出十个人;把父母放其中;然后只露出双眼;我能找出来;你的AI可以吗?百度说:我们可以马上修改我们的算法;专门用来学习眼镜的区别;一年后;可以超过人类; 我:"听起来你们的AI也不是很智能嘛";我只是稍微改了下规则;AI就挂了...
  • 6aa2e6281200:正在看原版 在google搜了一下看到了这份翻译 支持楼主
  • 209cd9bb6933:正好在写LSTM的项目,看到这篇文章真是雪中送炭。简明扼要的文字和清爽的排版真是太良心了。谢谢博主,走心了。已在微信打赏。
    朱小虎XiaohuZhu:@潘文武 谢谢支持~ :smiley:
  • d4c7b96e8183:支持作者,谢谢您的翻译!
  • a9a9336d5ab3:翻译的很棒!
  • 北静王:LSTM还是比较容易看懂的,不知道楼主啥时候能够写一篇LSTM的数学推导的文章。
    c4fbd798203e:@Not_GOD 期待!
    朱小虎XiaohuZhu:@北静王 考虑过段时间写一篇分析推导的
  • 37339516df86:好文章,受益良多~
  • 680aefadf62b:这里的W[h,x]是什么意思,讲h与x拼接成一个更长的向量?
    680aefadf62b:@Not_GOD 晓得了,谢谢:blush: (我没有团队,一个人做这个循环网络,理解起来比较费劲,一个细节就够我折腾一天的,有好的教程可以推荐一下么):flushed:
    朱小虎XiaohuZhu:本文中将 h 和 x 的权重矩阵整合在一个了 ,可能和其他一些地方的论文写得不同:)
    你可以展开一个 example 的公式看看
  • 神经旷野舞者:这个原图,是用什么软件画的啊
  • 么悾:想跟作者讨论下,文中说在从cell 到输出的过程中需要tanh转换,而在有些实现中并没有加tanh,而是直接cell*out_gate,引自https://github.com/nicodjimenez/lstm,请问这种不加tanh的情况普遍吗?对性能有无影响?希望能跟你多讨教!
    么悾:I found the answer in paper <An Empirical Exploration of Recurrent Network Architectures>: "We discovered that the input gate is important, that the output gate is unimportant, and that the forget gate is extremely significant on all problems except language modelling."
  • 8fd109c7cb0d:收获良多,翻译排版得很不错
  • bdca2bda41b1:感谢作者的翻译,不过这里有个疑问,是针对olah的文章的。原文中LSTM的这个单元,如果两条线汇聚代表“concatenate”的话,最初x_t和h_{t-1}两者连接之后,后面的维度都会加倍,这样h_t的维度其实就是h_{t-1}的二倍,如此一来,维度越扩越大啊。相反,看了Google在Udacity上的Deep Learning教程的关于LSTM的例子,他们的做法不是concatenate,而是把二者相加,保持维度相等。所以感觉olah的这个写法是不是有些问题?
    布客飞龙:假设你有个运算是 AB + CD,四个都是矩阵,那么等价于 AC 左右拼接,乘上 BD 上下拼接。
    c4fbd798203e:@friskit 原来是这样,谢谢!
    bdca2bda41b1:把公式整理了一下之后发现我差不多明白了。。主要的秘诀在于权值矩阵。比如说,x和h的维度是[m,1],两者concatenate之后维度是[2m, 1],所以只需要w的维度是[m, 2m], b的维度是[m, 1]就可以使得运算后的维度是[m, 1]了。
  • fighting41love:首先,非常感谢作者能够花时间翻译此文。辛苦了!
    不过这里有一点小问题需要讨论:
    文中这一部分:前主语的类别,因此正确的代词可以被选择出来。当我们看到新的主语,我们希望忘记旧的主语。

    这句翻译的有点问题。我猜作者是说 主语的性别,后面找正确的代词, she or he的意思,应该不是类别,是性别。
    朱小虎XiaohuZhu:感谢,已经修改。
  • zhwhong:Not_GOD大神这篇文章翻译和排版真好,最近在看LSTM,获益匪浅啊 :blush:
    朱小虎XiaohuZhu:@zhwhong 谢谢,多多交流哈 :grin:
  • xushiluo:翻译的好(✪▽✪)!
  • sizheng:Jozefowicz, et al. (2015) 则在超过 1 万种 RNN 架构上进行了测试,发现一些架构在某些任务上也取得了比 LSTM 更好的结果。——这工作量。。。
    d19a9882180f:看到这里我也惊呆了
    朱小虎XiaohuZhu:@sizheng 所以可以发jmlr,也是 google 忒任性
  • e51265bc0f3f:“让我们回到语言模型的例子中来基于已经看到的预测下一个词。在这个问题中,细胞状态可能包含当前主语的类别,因此正确的代词可以被选择出来。当我们看到新的代词,我们希望忘记旧的代词。” 是不是应该是“当我们看到新的主语”吧
    d12fd6e50d91:@Not_GOD 感谢大神的分享!
    朱小虎XiaohuZhu:@熊15 @zgkk 感谢两位指出,已经改好。~~ :blush:
    d12fd6e50d91:@zgkk 作者把原文的“subject”都翻译成了 “代词” ,个人觉着 翻译成 “主语”更好! 赞同!
  • 3a20afef2ee5:xuexile,xiexie
  • da90b75deea6:深入浅出,很喜欢。谢谢分享
  • 692167473964:获益匪浅
    朱小虎XiaohuZhu:@暖冬2016 :smile:
  • 68dc79f6d33d:不错,正好最近在学习。
  • 6c47a7eb6b4e:翻译的很棒! :+1:
  • de1799e4fd76:翻译的很好,很有用的干货,辛苦了。有一个小错误,“在我们语言模型的例子中,我们希望增加新的代词的类别到细胞状态中,来替代旧的需要忘记的代词”下边的配图第二个公式应该是C_t = tanh(W_c [ h_t-1, x_t] + b_c)。
    朱小虎XiaohuZhu:@hualitlc 谢谢指出,已经改了。
  • jiangnan_hugo:翻译的好。
    朱小虎XiaohuZhu:@jiangnan_hugo 谢谢
  • d4e584126d8d:已在微信打赏
  • d986d284aade:不是我吹逼呀 这排版很舒服了
    d4e584126d8d:@Not_GOD 图文并貌好文章。不过就是有些图因为上面的字小,想点开放大看,但因为放大后背景是黑的,所以一些模块的黑色连接线看不到了
    朱小虎XiaohuZhu:@大姨夫斯基 就第一幅图有点大。。。

本文标题:[译] 理解 LSTM 网络

本文链接:https://www.haomeiwen.com/subject/ijckcttx.html