【pytorch】LSTM | GRU使用

本文详细介绍了LSTM(长短期记忆网络)和GRU(门控循环单元)两种序列建模方法,包括它们的主要参数、使用方式及在多GPU训练中的注意事项。LSTM适用于需要记忆长期依赖信息的场景,而GRU则是LSTM的一种简化版本,两者在序列预测任务中都有广泛应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. LSTM

  • 长短期记忆网络,主要用于做序列建模用

  • 原理
    在这里插入图片描述

  • 主要参数
    在这里插入图片描述

    • batch_first:多gpu训练时要设置为True
    • bidirectional: True表示双向
    • input_size: 序列的特征维度
    • hidden_size:隐含层的特征维度
  • 使用

>>> rnn = nn.LSTM(10, 20, 2)
>>> input = torch.randn(5, 3, 10)		# seq, batch, features
>>> h0 = torch.randn(2, 3, 20)
>>> c0 = torch.randn(2, 3, 20)
>>> output, (hn, cn) = rnn(input, (h0, c0))
  • 说明
    • 一般在使用的时候都是省略了h,c。h是t时刻的隐藏状态,c是t时刻的单元格状态
    • 注意: 多GPU训练的时候,需要将batch放到最前面

2. GRU

  • 同样也是主要用于序列建模

  • 原理
    在这里插入图片描述

  • 主要参数
    在这里插入图片描述

    • 主要就是初始化和输入时
  • 使用

>>> rnn = nn.GRU(10, 20, 2)
>>> input = torch.randn(5, 3, 10)
>>> h0 = torch.randn(2, 3, 20)
>>> output, hn = rnn(input, h0)
  • 注意
    • h0 的特征shape是固定的(num_layers*num_directions, batch, hidden_size)
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值