FNN

定义

FNN(Feedforward Neural Network),即前馈神经网络,它是网络信息单向传递的一种神经网络,数据由输入层开始输入,依次流入隐藏层各层神经元,最终由输出层输出。其当前的输出只由当前的输入决定,任何层的输出都不会影响同级层。

以上图所示的神经网络为例,它在训练过程中通过前向计算和反向传播,不断通过调整权重系数Wi和Wo来实现学习目的。通常情况下,前馈神经网络会在空间上进行延伸,通过增加隐藏层层数与隐藏层神经元个数追求更好的学习效果。

缺点

前馈神经网络假定元素之间是相互独立的,对于序列数据,只能单独地处理序列中的每个元素,前一个输入与后一个输入在处理过程中也是完全独立的,无法捕获序列之间的依赖关系。

RNN

定义

RNN(Recurrent Neural Network),即循环神经网络,它是一种主要用来处理序列数据的神经网络,它关注了隐藏层每个神经元在时间维度上的变化,其中循环说成递推可能会更直观一些,本质就是同一个网络接收当前时刻的输入和上一时刻隐藏层神经元的输出,沿着时序反复迭代以实现对序列数据的学习。

结构

直观结构

在上图中, RNN 的每个时刻,输入层的x1和x2都在Wi的作用下传入隐藏层,上一时刻的隐藏层输出也通过Wh传入当前的隐藏层,因此它相当于可以间接访问之前的所有输入,这就是为什么说RNN可以保存记忆。

内部结构

上图展示了RNN在三个相邻时刻的计算逻辑。 在任意时刻t,隐藏层状态的计算可以被视为:

  1. 拼接t时刻的输入Xt和t−1时刻的隐藏层状态Ht−1,得到新的张量[Xt,Ht-1];
  2. 将新的张量送入带有激活函数φ的全连接层,激活函数常用tanh或者relu, 全连接层的输出是t时刻的隐藏层状态Ht

在t时刻,隐藏层状态Ht的计算公式为:

在t时刻,输出层的输出计算公式为:

参数说明:

  • Xt是t时刻的输入,它是一个向量;
  • Wi是输入层到隐藏层的权重矩阵;
  • Ht-1是t-1时刻的隐藏层状态,在初始时刻,会给隐藏层设置初始状态H0
  • Wh是隐藏层上一时刻的值作用于当前时刻的权重矩阵;
  • Wo是隐藏层到输出层的权重矩阵;
  • bh是和bo是偏置系数。

注意:

  • 在不同时刻,RNN总是使用这些模型参数,其参数开销不会随着时间的增加而增加。
  • 隐藏层状态中XtWi+Ht-1Wh的计算,相当于Xt和Ht-1的拼接与Wi和Wh的拼接进行矩阵乘法。
  • RNN和前馈神经网络一样,也是通过反向传播来更新权重,以达到学习的效果。

应用

1-N类型,输入一张图片,输出一段话或者一段音乐,利用它可以实现看图说话。

N-1类型,输入一段话,输出对其情感类别的判断,利用它可以实现文本分类。

N-N类型,输入和输出是等长的序列,可以用来生成等长的诗歌。

N-M类型,输入和输出是不等长的序列,也被叫做Encoder-Decoder模型或Seq2Seq模型,可以应用在机器翻译、文本摘要、阅读理解等多个领域上。

变体

BRNN(Bidirectional RNN)

RNN的一个主要问题是只能从以往的输入进行学习,也就是只能理解上下文中的上文,为了拥有更好的学习效果,因此提出了双向RNN,也就是BRNN。 BRNN会在原有RNN的基础上再加一个隐藏层,该隐藏层的状态是从后向前传播的,从序列的终点开始读取,称为后向层;而原有的从序列起点开始读取的隐藏层称为前向层。 BRNN的隐藏层状态的计算可以被视为:

  1. 根据输入序列计算前向层隐藏层状态H1
  2. 将输入序列反转,计算后向层隐藏层状态H2
  3. 将H1和H2拼接起来,得到最终隐藏层状态H,H=[H1,H2]。

注意,只有能拿到整个输入序列时才能使用BRNN 。

DRNN(Deep RNN)

与前馈神经网络不同,RNN因为考虑了时间维度,隐藏层达到三层就算多的了。

优缺点

优点

  • RNN可以处理序列信息,且内部结构简单,对计算资源的要求低。

缺点

  • RNN是一个时序模型,每个时刻的计算都依赖于前一时刻的结果,计算速度慢;

  • RNN由于梯度消失,难以支持长序列,不能捕获序列中长期的依赖关系;

  • RNN网络在时间维度上是串联的,离当前时间越远的隐藏层输出,对当前隐藏层的输出影响越小,它无法根据不同词本身的重要性对当前的输出产生影响;

  • RNN对所有输入是同等对待的,提取了所有的信息,没有区分有用信息、无用信息和辅助信息。但是如果某个网络可以根据不同输入的重要性,选择性地丢弃和记忆,就可以使得有效信息即使距离当前时间较远,也能有较大影响,实现长期记忆,这就引出了LSTM。

主要参考

最新文章

  1. 机器学习基础与实践(三)----数据降维之PCA
  2. 本周PSP流程进度
  3. MySQL学习笔记十五:优化(2)
  4. Javascript验证手机号码正则表达式
  5. C语言回顾-函数和位运算
  6. 移动统计工具Flurry
  7. nyoj 329 循环小数【KMP】【求最小循环节长度+循环次数+循环体】
  8. [原创]NT系统信息察看工具 : NtInfoGuy
  9. jQuery UI 日期选择器(Datepicker)
  10. 软件开发:网站&视频&书籍推荐(不断更新)
  11. windows 10下通过python3.6成功搭建jupyter 服务器
  12. linux中,history命令,显示时间戳?操作人?IP地址?
  13. oracle查询buffer cache中undo大小
  14. 使用mpvue开发小程序
  15. oracle 回退表空间清理
  16. StringBuilder和+来串接字符串,时间的比较
  17. ocacle sql: 两张表左连接 ,1对多,取一条数据,取按时间最新的
  18. opensuse编译安装Python3后缺少zlib
  19. jquery复选框 选中事件 及其判断是否被选中_常用笔记
  20. [转]SVN服务器搭建和使用(一)

热门文章

  1. Linux_etc-shadow文件总结
  2. MySQL建表语句生成Golang代码
  3. Sublime Text简单使用方法
  4. 华南理工大学 Python第6章课后测验-1
  5. .NET WebAPI 自定义 NullableConverter 解决请求入参 “”空字符触发转换异常问题
  6. 查询参数: Query Parameters
  7. 第五章:Admin管理后台
  8. rook-ceph说明
  9. DevExpress弹框、右键菜单、Grid的使用
  10. Python实现改进后的Bi-RRT算法实例