婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > pytorch lstm gru rnn 得到每個state輸出的操作

pytorch lstm gru rnn 得到每個state輸出的操作

熱門標(biāo)簽:儋州電話機器人 市場上的電銷機器人 小蘇云呼電話機器人 佛山400電話辦理 朝陽手機外呼系統(tǒng) 所得系統(tǒng)電梯怎樣主板設(shè)置外呼 北瀚ai電銷機器人官網(wǎng)手機版 北京電銷外呼系統(tǒng)加盟 地圖標(biāo)注面積

默認(rèn)只返回最后一個state,所以一次輸入一個step的input

# coding=UTF-8
import torch
import torch.autograd as autograd  # torch中自動計算梯度模塊
import torch.nn as nn  # 神經(jīng)網(wǎng)絡(luò)模塊
torch.manual_seed(1)
# lstm單元輸入和輸出維度都是3
lstm = nn.LSTM(input_size=3, hidden_size=3)
# 生成一個長度為5,每一個元素為1*3的序列作為輸入,這里的數(shù)字3對應(yīng)于上句中第一個3
inputs = [autograd.Variable(torch.randn((1, 3)))
          for _ in range(5)]
# 設(shè)置隱藏層維度,初始化隱藏層的數(shù)據(jù)
hidden = (autograd.Variable(torch.randn(1, 1, 3)),
          autograd.Variable(torch.randn((1, 1, 3))))
for i in inputs:
  out, hidden = lstm(i.view(1, 1, -1), hidden)
  print(out.size())
  print(hidden[0].size())
  print("--------")
print("-----------------------------------------------")
# 下面是一次輸入多個step的樣子
inputs_stack = torch.stack(inputs)
out,hidden = lstm(inputs_stack,hidden)
print(out.size())
print(hidden[0].size())

print結(jié)果:

(1L, 1L, 3L)
(1L, 1L, 3L)
--------
(1L, 1L, 3L)
(1L, 1L, 3L)
--------
(1L, 1L, 3L)
(1L, 1L, 3L)
--------
(1L, 1L, 3L)
(1L, 1L, 3L)
--------
(1L, 1L, 3L)
(1L, 1L, 3L)
--------
----------------------------------------------
(5L, 1L, 3L)
(1L, 1L, 3L)

可見LSTM的定義都是不用變的,根據(jù)input的step數(shù)目,一次輸入多少step,就一次輸出多少output,但只輸出最后一個state

補充:pytorch中實現(xiàn)循環(huán)神經(jīng)網(wǎng)絡(luò)的基本單元RNN、LSTM、GRU的輸入、輸出、參數(shù)詳細(xì)理解

前言:這篇文章是對已經(jīng)較為深入理解了RNN、LSTM、GRU的數(shù)學(xué)原理以及運算過程的人而言的,如果不理解它的基本思想和過程,可能理解起來不是很簡單。

一、先從一個實例看起

這是官網(wǎng)上面的一個例子,本次以LSTM作為例子而言,實際上,GRU、LSTM、RNN的運算過程是很類似的。

import torch
import torch.nn as nn
 
lstm = nn.LSTM(10, 20, 2)
 
# 序列長度seq_len=5, batch_size=3, 數(shù)據(jù)向量維數(shù)=10
input = torch.randn(5, 3, 10)
 
# 初始化的隱藏元和記憶元,通常它們的維度是一樣的
# 2個LSTM層,batch_size=3,隱藏元維度20
h0 = torch.randn(2, 3, 20)
c0 = torch.randn(2, 3, 20)
 
# 這里有2層lstm,output是最后一層lstm的每個詞向量對應(yīng)隱藏層的輸出,其與層數(shù)無關(guān),只與序列長度相關(guān)
# hn,cn是所有層最后一個隱藏元和記憶元的輸出
output, (hn, cn) = lstm(input, (h0, c0))
 
print(output.size(),hn.size(),cn.size())
 
# 分別是:
# torch.Size([5, 3, 20])
# torch.Size([2, 3, 20])
# torch.Size([2, 3, 20]))

后面我會詳細(xì)解釋上面的運算過程,我們先看一下LSTM的定義,它是一個類

二、LSTM類的定義

class LSTM(RNNBase):
   
    '''參數(shù)Args:
        input_size: 輸入數(shù)據(jù)的特征維度,比如我對時間序列建模,特征為1,我對一個句子建模,每一個單詞的嵌入向量為10,則它為10
        
        hidden_size: 即循環(huán)神經(jīng)網(wǎng)絡(luò)中隱藏節(jié)點的個數(shù),這個是自己定義的,多少都可以,后面會詳說
        
        num_layers: 堆疊的LSTM的層數(shù),默認(rèn)是一層,也可以自己定義 Default: 1
        bias: LSTM層是否使用偏置矩陣 偏置權(quán)值為 `b_ih` and `b_hh`.
            Default: ``True``(默認(rèn)是使用的)
        
        batch_first: 如果設(shè)置 ``True``, then the input and output tensors are provided
            as (batch, seq, feature). Default: ``False``,(seq,batch,features)
        dropout: 是否使用dropout機制,默認(rèn)是0,表示不使用dropout,如果提供一個非0的數(shù)字,則表示在每一個LSTM層之后默認(rèn)使用dropout,但是最后一個層的LSTM層不使用dropout。
        
        bidirectional: 是否是雙向RNN,默認(rèn)是否,If ``True``, becomes a bidirectional LSTM. Default: ``False``
#---------------------------------------------------------------------------------------
    類的構(gòu)造函數(shù)的輸入為Inputs: input, (h_0, c_0)
        - **input** of shape `(seq_len, batch, input_size)`: tensor containing the features of the input sequence.
          
        - **h_0** of shape `(num_layers * num_directions, batch, hidden_size)`: tensor
          containing the initial hidden state for each element in the batch.
          If the LSTM is bidirectional, num_directions should be 2, else it should be 1.
        - **c_0** of shape `(num_layers * num_directions, batch, hidden_size)`: tensor
          containing the initial cell state for each element in the batch.
          If `(h_0, c_0)` is not provided, both **h_0** and **c_0** default to zero.
#----------------------------------------------------------------------------------
    輸出是什么:Outputs: output, (h_n, c_n)
        - **output** of shape `(seq_len, batch, num_directions * hidden_size)`: tensor
          containing the output features `(h_t)` from the last layer of the LSTM,
          for each `t`. If a :class:`torch.nn.utils.rnn.PackedSequence` has been
          given as the input, the output will also be a packed sequence.
          For the unpacked case, the directions can be separated
          using ``output.view(seq_len, batch, num_directions, hidden_size)``,
          with forward and backward being direction `0` and `1` respectively.
          Similarly, the directions can be separated in the packed case.
        
        - **h_n** of shape `(num_layers * num_directions, batch, hidden_size)`: tensor
          containing the hidden state for `t = seq_len`.
          Like *output*, the layers can be separated using
          ``h_n.view(num_layers, num_directions, batch, hidden_size)`` and similarly for *c_n*.
        
        - **c_n** of shape `(num_layers * num_directions, batch, hidden_size)`: tensor
          containing the cell state for `t = seq_len`.
#------------------------------------------------------------------------------------------
    類的屬性有Attributes:
        weight_ih_l[k] : the learnable input-hidden weights of the :math:`\text{k}^{th}` layer
            `(W_ii|W_if|W_ig|W_io)`, of shape `(4*hidden_size, input_size)` for `k = 0`.
            Otherwise, the shape is `(4*hidden_size, num_directions * hidden_size)`
        weight_hh_l[k] : the learnable hidden-hidden weights of the :math:`\text{k}^{th}` layer
            `(W_hi|W_hf|W_hg|W_ho)`, of shape `(4*hidden_size, hidden_size)`
        bias_ih_l[k] : the learnable input-hidden bias of the :math:`\text{k}^{th}` layer
            `(b_ii|b_if|b_ig|b_io)`, of shape `(4*hidden_size)`
        bias_hh_l[k] : the learnable hidden-hidden bias of the :math:`\text{k}^{th}` layer
            `(b_hi|b_hf|b_hg|b_ho)`, of shape `(4*hidden_size)`
    '''

上面的參數(shù)有點多,我就不一個一個翻譯了,其實很好理解,每一個都比較清晰。

三、 必需參數(shù)的深入理解

1、RNN、GRU、LSTM的構(gòu)造函數(shù)的三個必須參數(shù)理解——第一步:構(gòu)造循環(huán)層對象

在創(chuàng)建循環(huán)層的時候,第一步是構(gòu)造循環(huán)層,如下操作:

lstm = nn.LSTM(10, 20, 2)

構(gòu)造函數(shù)的參數(shù)列表為如下:

class LSTM(RNNBase):
   
    '''參數(shù)Args:
        input_size:
        hidden_size:         
        num_layers: 
        bias:       
        batch_first: 
        dropout: 
        bidirectional:
    '''

(1)input_size:指的是每一個單詞的特征維度,比如我有一個句子,句子中的每一個單詞都用10維向量表示,則input_size就是10;

(2)hidden_size:指的是循環(huán)層中每一個LSTM內(nèi)部單元的隱藏節(jié)點數(shù)目,這個是自己定義的,隨意怎么設(shè)置都可以;

(3)num_layers:循環(huán)層的層數(shù),默認(rèn)是一層,這個根據(jù)自己的情況來定。

比如下面:

左邊的只有一層循環(huán)層,右邊的有兩層循環(huán)層。

2、通過第一步構(gòu)造的對象構(gòu)造前向傳播的過程——第二步:調(diào)用循環(huán)層對象,傳入?yún)?shù),并得到返回值

一般如下操作:

output, (hn, cn) = lstm(input, (h0, c0))

這里是以LSTM為例子來說的,

(1)輸入?yún)?shù)

input:必須是這樣的格式(seq,batch,feature)。第一個seq指的是序列的長度,這是根據(jù)自己的數(shù)據(jù)來定的,比如我的一個句子最大的長度是20個單詞組成,那這里就是20,上面的例子是假設(shè)句子長度為5;第二個是batch,這個好理解,就是一次使用幾條樣本,比如3組樣本;第三個features指的是每一個單詞的向量維度,需要注意的是,這個必須要和構(gòu)造函數(shù)的第一個參數(shù)input_size保持一樣的,上面的例子中是10.

(h0,c0):指的是每一個循環(huán)層的初始狀態(tài),可以不指定,不指定的情況下全部初始化為0,這里因為是LSTM有兩個狀態(tài)需要傳遞,所以有兩個,像普通的RNN和GRU只有一個狀態(tài)需要傳遞,則只需要傳遞一個h狀態(tài)即可,如下:

output, hn = rnn(input, h0)  # 普通rnn
output, hn = gru(input, h0)  # gru

這里需要注意的是傳入的狀態(tài)參數(shù)的維度,依然以LSTM來說:

h0和c0的數(shù)據(jù)維度均是(num_layers * num_directions, batch, hidden_size),這是什么意思呢?

第一個num_layer指的是到底有基層循環(huán)層,這好理解,幾層就應(yīng)該有幾個初始狀態(tài);

第二個num_directions指的是這個循環(huán)層是否是雙向的(在構(gòu)造函數(shù)中通過bidirectional參數(shù)指定哦),如果不是雙向的,則取值為1,如果是雙向的則取值為2;

第三個batch指的是每次數(shù)據(jù)的batch,和前面的batch保持一致即可;

最后一個hidden_size指的是循環(huán)層每一個節(jié)點內(nèi)部的隱藏節(jié)點數(shù),這個需要很好地理解循環(huán)神經(jīng)網(wǎng)絡(luò)的整個運算流程才行哦!

(2)輸出結(jié)果

其實輸出的結(jié)果和輸入的是相匹配的,分別如下:

output, hn = rnn(input, h0)  # 普通rnn
output, hn = gru(input, h0)  # gru
output, (hn, cn) = lstm(input, (h0, c0)) # lstm

這里依然以lstm而言:

output的輸出維度(seq_len, batch, num_directions * hidden_size),在上面的例子中,應(yīng)該為(5,3,20),我們通過驗證的確如此,需要注意的是,第一個維度是seq_len,也就是說每一個時間點的輸出都是作為輸出結(jié)果的,這和隱藏層是不一樣的;

hn、cn的輸出維度:為(num_layers * num_directions, batch, hidden_size),在上面的例子中為(2,3,20),也得到了驗證,我們發(fā)現(xiàn)這個跟序列長度seq_len是沒有關(guān)系的,為什么呢,輸出的狀態(tài)僅僅是指的是最后一個循環(huán)層節(jié)點輸出的狀態(tài)。

如下圖所示:

下面的例子是以普通的RNN來畫的,所以只有一個狀態(tài)h,沒有狀態(tài)c。

3、幾個重要的屬性理解

不管是RNN,GRU還是lstm,內(nèi)部可學(xué)習(xí)的參數(shù)其實就是幾個權(quán)值矩陣,包括了偏置矩陣,那怎么查看這些學(xué)習(xí)到的參數(shù)呢?就是通過這幾個矩陣來實現(xiàn)的

(1)weight_ih_l[k]:這表示的是輸入到隱藏層之間的權(quán)值矩陣,其中K表示的第幾層循環(huán)層,

若K=0,表示的是最下面的輸入層到第一個循環(huán)層之間的矩陣,維度為(hidden_size, input_size),如果k>0則表示第一循環(huán)層到第二循環(huán)層、第二循環(huán)層到第三循環(huán)層,以此類推,之間的權(quán)值矩陣,形狀為(hidden_size, num_directions * hidden_size)。

(2)weight_hh_l[k]: 表示的是循環(huán)層內(nèi)部之間的權(quán)值矩陣,這里的K表示的第幾層循環(huán)層,取值為0,1,2,3,4... ...。形狀為(hidden_size, hidden_size)

注意:循環(huán)層的層數(shù)取值是從0開始,0代表第一個循環(huán)層,1代表第二個循環(huán)層,以此類推。

(3)bias_ih_l[k]: 第K個循環(huán)層的偏置項,表示的是輸入到循環(huán)層之間的偏置,維度為 (hidden_size)

(4)bias_hh_l[k]:第K個循環(huán)層的偏置項,表示的是循環(huán)層到循環(huán)層內(nèi)部之間的偏置,維度為 (hidden_size)

# 首先導(dǎo)入RNN需要的相關(guān)模塊
import torch
import torch.nn as nn
 
# 數(shù)據(jù)向量維數(shù)10, 隱藏元維度20, 2個RNN層串聯(lián)(如果是1,可以省略,默認(rèn)為1)
rnn = nn.RNN(10, 20, 2)
 
# 序列長度seq_len=5, batch_size=3, 數(shù)據(jù)向量維數(shù)=10
input = torch.randn(5, 3, 10)
 
# 初始化的隱藏元和記憶元,通常它們的維度是一樣的
# 2個RNN層,batch_size=3,隱藏元維度20
h0 = torch.randn(2, 3, 20)
 
# 這里有2層RNN,output是最后一層RNN的每個詞向量對應(yīng)隱藏層的輸出,其與層數(shù)無關(guān),只與序列長度相關(guān)
# hn,cn是所有層最后一個隱藏元和記憶元的輸出
output, hn = rnn(input, h0)
 
print(output.size(),hn.size()) # 分別是:torch.Size([5, 3, 20])   torch.Size([2, 3, 20])
 
# 查看一下那幾個重要的屬性:
print("------------輸入--》隱藏------------------------------")
print(rnn.weight_ih_l0.size())  
print(rnn.weight_ih_l1.size())
print(rnn.bias_ih_l0.size())
print(rnn.bias_ih_l1.size())
print("------------隱藏--》隱藏------------------------------")
print(rnn.weight_hh_l0.size())  
print(rnn.weight_hh_l1.size())
print(rnn.bias_hh_l0.size())
print(rnn.bias_hh_l1.size())
 
'''輸出結(jié)果為:
------------輸入--》隱藏------------------------------
torch.Size([20, 10])
torch.Size([20, 20])
torch.Size([20])
torch.Size([20])
------------隱藏--》隱藏------------------------------
torch.Size([20, 20])
torch.Size([20, 20])
torch.Size([20])
torch.Size([20])
'''

通過上面的運算,發(fā)現(xiàn)結(jié)果和描述的是一模一樣的。

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • Pytorch實現(xiàn)LSTM和GRU示例
  • pytorch下使用LSTM神經(jīng)網(wǎng)絡(luò)寫詩實例
  • TensorFlow實現(xiàn)RNN循環(huán)神經(jīng)網(wǎng)絡(luò)
  • Pytorch 如何實現(xiàn)LSTM時間序列預(yù)測

標(biāo)簽:定西 江蘇 商丘 云南 寧夏 酒泉 龍巖 金融催收

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《pytorch lstm gru rnn 得到每個state輸出的操作》,本文關(guān)鍵詞  pytorch,lstm,gru,rnn,得到,每個,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《pytorch lstm gru rnn 得到每個state輸出的操作》相關(guān)的同類信息!
  • 本頁收集關(guān)于pytorch lstm gru rnn 得到每個state輸出的操作的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    麻豆精品国产91久久久久久| 日韩不卡手机在线v区| 亚洲最大的成人av| 色诱亚洲精品久久久久久| 亚洲国产成人午夜在线一区| 蜜臂av日日欢夜夜爽一区| 欧美电影免费提供在线观看| 久久99久久99小草精品免视看| 日韩三级视频在线观看| 国产精品亚洲成人| 中文字幕一区二区三区色视频| 91蜜桃在线免费视频| 亚洲综合丁香婷婷六月香| 欧美日韩高清在线| 麻豆精品蜜桃视频网站| 国产欧美久久久精品影院| 一本色道亚洲精品aⅴ| 综合久久国产九一剧情麻豆| 波多野洁衣一区| 曰韩精品一区二区| 91麻豆精品久久久久蜜臀| 亚洲成人综合网站| 4438x亚洲最大成人网| 免费在线观看一区| 久久久一区二区三区| 99国内精品久久| 国产精品久久久久aaaa| 99久久伊人网影院| 日韩制服丝袜av| 中文在线免费一区三区高中清不卡| 在线免费观看日本欧美| 韩国精品久久久| 亚洲在线免费播放| 欧美国产国产综合| 欧美一区二区久久久| 99久久综合色| 国产精品一区在线| 视频一区中文字幕国产| 亚洲男人的天堂在线aⅴ视频| 欧美大片日本大片免费观看| 欧美天堂亚洲电影院在线播放| 国精品**一区二区三区在线蜜桃 | 精品一区二区三区视频| 亚洲人成人一区二区在线观看 | 亚洲免费观看高清完整版在线 | 国产精品一级片| 亚洲四区在线观看| 91精品国产欧美日韩| av资源网一区| 国产精品一级在线| 午夜电影网亚洲视频| 亚洲欧美成人一区二区三区| 国产日韩欧美电影| 2022国产精品视频| 精品国产凹凸成av人导航| 欧美另类高清zo欧美| 在线视频观看一区| 99精品一区二区三区| 国产精品亚洲专一区二区三区 | 成人黄色777网| 狠狠色狠狠色综合| 国产一区二区视频在线| 经典三级一区二区| 久久国产综合精品| 国产尤物一区二区| 国内久久婷婷综合| 精品一区二区久久| 国产福利一区二区| 国产a级毛片一区| 国产久卡久卡久卡久卡视频精品| 国精产品一区一区三区mba视频| 久久99久久精品| 国产综合久久久久影院| 成人免费视频视频在线观看免费 | 91精品国产高清一区二区三区蜜臀| 欧美日韩在线播放三区四区| 欧美日韩一区二区在线观看 | 精品成人免费观看| 精品国产一区二区在线观看| 精品福利一区二区三区免费视频| 91精品国产综合久久精品性色| 在线不卡欧美精品一区二区三区| 欧美久久久久免费| 久久综合久久综合亚洲| 久久伊人中文字幕| 一色屋精品亚洲香蕉网站| 亚洲美女屁股眼交3| 亚洲精品国产高清久久伦理二区| 亚洲午夜成aⅴ人片| 免费高清在线视频一区·| 日产国产欧美视频一区精品| 美美哒免费高清在线观看视频一区二区| 精品一区二区三区av| 成人av资源在线观看| 51精品秘密在线观看| 欧美高清在线视频| 日韩高清不卡一区| 99精品欧美一区二区蜜桃免费 | 久久久久久久久一| 亚洲福中文字幕伊人影院| 久久精品国产精品亚洲红杏 | 白白色 亚洲乱淫| 91麻豆精品国产91久久久| 国产精品色哟哟网站| 亚洲不卡一区二区三区| 国产米奇在线777精品观看| 91国偷自产一区二区三区成为亚洲经典| 欧美日韩美少妇| 中文字幕乱码久久午夜不卡| 偷拍一区二区三区| 色婷婷久久一区二区三区麻豆| 久久久99免费| 亚洲成人av中文| 色综合激情五月| 国产精品亲子乱子伦xxxx裸| 看电视剧不卡顿的网站| 色先锋久久av资源部| 国产喷白浆一区二区三区| 视频一区视频二区中文字幕| 色综合久久88色综合天天 | 韩国精品一区二区| 欧美日韩的一区二区| 成人免费在线视频观看| 国产精品中文字幕日韩精品| 7777精品伊人久久久大香线蕉 | 国产三级精品在线| 免费观看成人av| 日韩视频免费观看高清完整版在线观看 | 99久久er热在这里只有精品66| 欧美肥妇毛茸茸| 亚洲成在人线在线播放| 欧美在线观看禁18| 亚洲黄色免费电影| 色婷婷国产精品| 亚洲最新在线观看| 欧美日韩中文一区| 一区二区三区四区国产精品| 色综合 综合色| 亚洲激情网站免费观看| 色吧成人激情小说| 亚洲美女在线国产| 欧美体内she精高潮| 一区二区高清在线| 91精品国产综合久久久久久漫画| 日韩成人一区二区| 欧美一区二区三区视频在线观看| 国产精品人人做人人爽人人添| 大胆欧美人体老妇| 一区二区在线观看av| 在线这里只有精品| 日本人妖一区二区| 国产偷国产偷亚洲高清人白洁| 成人高清视频免费观看| 中文字幕亚洲在| 欧美在线啊v一区| 狂野欧美性猛交blacked| 久久精品一区八戒影视| 成人午夜看片网址| 国产精品天美传媒| 国产精品18久久久久久vr| 久久综合九色综合久久久精品综合| 经典三级视频一区| 国产精品美女久久久久av爽李琼| 91亚洲国产成人精品一区二区三 | 18涩涩午夜精品.www| 色综合中文字幕| 日产欧产美韩系列久久99| 日韩视频国产视频| 99国产精品久久久久久久久久| 一二三区精品视频| 久久欧美一区二区| 欧美在线观看一区| 国产成人久久精品77777最新版本 国产成人鲁色资源国产91色综 | 欧美成va人片在线观看| 91污片在线观看| 狠狠狠色丁香婷婷综合激情 | 一个色妞综合视频在线观看| 欧美一区二区在线免费播放| 国产福利91精品| 日本不卡中文字幕| 亚洲精品免费电影| 国产亚洲精品福利| 欧美理论在线播放| 色综合久久66| www.成人网.com| 国产精品一卡二| 久久国产精品一区二区| 亚洲免费观看高清| 中文一区二区在线观看| 欧美成人精品1314www| 欧美日韩在线电影| 日本丶国产丶欧美色综合| 国产成人亚洲综合a∨婷婷| 三级欧美韩日大片在线看| 亚洲人快播电影网| 亚洲婷婷综合久久一本伊一区| 久久久久久9999| 久久一区二区视频| 精品国产免费一区二区三区香蕉| 欧美日韩国产综合视频在线观看 |