RNN与LSTM详解:AI是如何“记住”信息的?

RNN(循环神经网络)的基本原理

RNN是一种处理序列数据的神经网络,其核心在于通过隐藏状态(hidden state)传递历史信息。每个时间步的输入不仅包括当前数据,还包含上一时间步的隐藏状态,形成循环连接。数学表达为:

h_t = \\sigma(W_{xh}x_t + W_{hh}h_{t-1} + b_h)

其中,h_t是当前隐藏状态,x_t是输入,W为权重矩阵,b为偏置,\\sigma为激活函数(如tanh)。

RNN的局限性

传统RNN存在梯度消失或爆炸问题,难以捕获长距离依赖关系。例如,在文本生成任务中,早期的单词信息可能无法有效传递到后续时间步。


LSTM(长短期记忆网络)的改进

LSTM通过引入门控机制(输入门、遗忘门、输出门)和细胞状态(cell state)解决RNN的缺陷。其核心结构如下:

遗忘门 :决定哪些信息从细胞状态中丢弃

f_t = \\sigma(W_f \\cdot \[h_{t-1}, x_t\] + b_f)

输入门 :更新细胞状态

i_t = \\sigma(W_i \\cdot \[h_{t-1}, x_t\] + b_i) \\ \\tilde{C}*t = \\tanh(W_C \\cdot \[h*{t-1}, x_t\] + b_C)

细胞状态更新

C_t = f_t \\odot C_{t-1} + i_t \\odot \\tilde{C}_t

输出门 :控制当前隐藏状态输出

o_t = \\sigma(W_o \\cdot \[h_{t-1}, x_t\] + b_o) \\ h_t = o_t \\odot \\tanh(C_t)


实际应用差异

RNN适用场景 :短序列任务(如字符级文本生成),计算资源有限时。
LSTM适用场景:长序列任务(如机器翻译、语音识别),需捕获长期依赖关系。

代码示例(PyTorch实现LSTM单元)

python 复制代码
import torch.nn as nn
lstm = nn.LSTM(input_size=100, hidden_size=128, num_layers=2)
input_seq = torch.randn(10, 3, 100)  # (seq_len, batch, input_size)
output, (h_n, c_n) = lstm(input_seq)

关键结论

  • RNN通过循环连接传递信息,但受限于梯度问题。
  • LSTM的门控机制和细胞状态设计显式控制信息流,更适合长期记忆。
  • 现代变体(如GRU)在LSTM基础上进一步简化结构,平衡性能与效率。
相关推荐
一点一木18 小时前
🚀 2026 年 4 月 GitHub 十大热门项目排行榜 🔥
人工智能·github
淡海水19 小时前
【AI模型】常见问题与解决方案
人工智能·深度学习·机器学习
HIT_Weston19 小时前
65、【Agent】【OpenCode】用户对话提示词(费米估算)
人工智能·agent·opencode
njsgcs19 小时前
我的知识是以图片保存的,我的任务状态可能也与图片有关,我把100张知识图片丢给vlm实时分析吗
人工智能
星爷AG I19 小时前
20-4 长时工作记忆(AGI基础理论)
人工智能·agi
#卢松松#20 小时前
用秒悟(meoo)制作了一个GEO查询小工具。
人工智能·创业创新
zandy101120 小时前
Agentic BI 架构实战:当AI Agent接管数据建模、指标计算与可视化全链路
人工智能·架构
数字供应链安全产品选型20 小时前
关键领域清单+SBOM:834号令下软件供应链的“精准治理“逻辑与技术落地路径
人工智能·安全
Flying pigs~~20 小时前
RAG智慧问答项目
数据库·人工智能·缓存·微调·知识库·rag
zuozewei20 小时前
从线下到等保二级生产平台:一次公有云新型电力系统 AI 部署复盘
人工智能