图解循环神经网络(RNN)

目录

1.循环神经网络介绍

2.网络结构

3.结构分类

4.模型工作原理

5.模型工作示例

6.总结


1.循环神经网络介绍

RNN(Recurrent Neural Network,循环神经网络)是一种专门用于处理序列数据的神经网络结构。与传统的神经网络不同,RNN具有记忆能力,能够捕捉序列数据中的时间依赖关系。

也就是说相比其他仅靠输入单一预测结果的神经网络,循环神经网络可以考虑前面输入的多个因素。比如现在流行的语言模型,他能记住你前面输入的内容,当你新输入某一个问题时候,他会去寻找是否和你前面输入的问题有联系。

2.网络结构

RNN的基本结构包括输入层、隐藏层和输出层。在每个时间步,RNN都会接收当前的输入数据(如一个词的嵌入表示)和前一个时间步的隐藏状态,然后生成一个新的隐藏状态和输出。这个新的隐藏状态不仅包含了当前时间步的信息,还融合了之前所有时间步的信息,因此RNN能够捕捉到序列数据中的上下文信息。

具体来说,RNN的隐藏状态是记忆部分,它在每个时间步都会被更新。隐藏状态的计算通常包括将当前时间步的输入数据和前一个时间步的隐藏状态传递给一个激活函数(如tanh或ReLU),从而生成新的隐藏状态。这个隐藏状态随后会被用作下一个时间步的输入之一,同时也可能用于生成当前时间步的输出。

3.结构分类

一对一结构:单个神经网络,即输入和输出都是单个值或向量。

一对多结构:单一输入转为序列输出。这类RNN可以处理图片,然后输出图片的描述信息。

多对一结构:序列输入转为单个输出。这种结构多用在电影评价分析等领域。

N对N结构:输入输出等长序列。这类限制比较大,常见的应用有作诗机器人等。

多对多结构(Seq2Seq结构):输入输出不等长的多对多结构,又叫Encoder-Decoder模型。这种结构的应用范围非常广泛,包括语言翻译、文本摘要、阅读理解、对话生成等。

4.模型工作原理

初始化状态:在序列的开始,RNN会有一个初始隐藏状态,通常是一个零向量或通过某种方式初始化。

序列处理:对于序列中的每个元素,RNN会计算当前时间步的隐藏状态。这通常通过一个激活函数(如tanh或ReLU)来完成。

信息传递:隐藏状态会传递到下一个时间步,与新的输入一起更新。

输出生成:在每个时间步,RNN可以生成一个输出,这通常通过另一个激活函数来完成。

序列结束:当序列结束时,RNN可以输出最终的隐藏状态,或者通过一个额外的输出层来生成最终的预测。

5.模型工作示例

对于一个词汇表,先将其转换成向量的形式。

这里那填词案例来演示,就是说当一段词语有一个空白需要填词,一般的神经网络是考虑前一个词语来预测这个空白,而循环神经网络不光是考虑空白前的那个词,还会考虑前面的已有的词,进一步预测空白处的词语,RNN可以捕捉到前面输入词语之间的联系,提高填入的词语的准确度。

通过RNN的隐藏层获取输入之间的联系,下一个输入的同时会联系到上一个输入的隐藏状态,当输入结束时候输出最终的结果。

6.总结

循环神经网络可以很好的捕捉到之前的各项输入之间的联系,相对于其他传统的神经网络更加灵活,应用的场景也更多,结果也更准确。并且RNN中的权重参数是共享的,这有助于减少模型的参数数量并提高计算效率。但是循环神经网络也存在一些不足,比如梯度消失和梯度爆炸问题:在长序列任务中,RNN容易出现梯度消失或梯度爆炸的问题,导致模型难以训练。

相关推荐
LO嘉嘉VE5 分钟前
学习笔记二十一:深度学习
笔记·深度学习·学习
YJlio1 小时前
[编程达人挑战赛] 用 PowerShell 写了一个“电脑一键初始化脚本”:从混乱到可复制的开发环境
数据库·人工智能·电脑
RoboWizard1 小时前
PCIe 5.0 SSD有无独立缓存对性能影响大吗?Kingston FURY Renegade G5!
人工智能·缓存·电脑·金士顿
霍格沃兹测试开发学社-小明2 小时前
测试左移2.0:在开发周期前端筑起质量防线
前端·javascript·网络·人工智能·测试工具·easyui
懒麻蛇2 小时前
从矩阵相关到矩阵回归:曼特尔检验与 MRQAP
人工智能·线性代数·矩阵·数据挖掘·回归
xwill*2 小时前
RDT-1B: A DIFFUSION FOUNDATION MODEL FOR BIMANUAL MANIPULATION
人工智能·pytorch·python·深度学习
网安INF2 小时前
机器学习入门:深入理解线性回归
人工智能·机器学习·线性回归
陈奕昆2 小时前
n8n实战营Day2课时2:Loop+Merge节点进阶·Excel批量校验实操
人工智能·python·excel·n8n
程序猿追2 小时前
PyTorch算子模板库技术解读:无缝衔接PyTorch模型与Ascend硬件的桥梁
人工智能·pytorch·python·深度学习·机器学习
程序小旭2 小时前
Kaggle平台的使用
人工智能