【发布时间】:2018-12-11 15:42:44
【问题描述】:
我正在阅读this 教程。我对以下课程代码有疑问:
class RNN(nn.Module):
def __init__(self, input_size, hidden_size, output_size):
super(RNN, self).__init__()
self.input_size = input_size
self.hidden_size = hidden_size
self.output_size = output_size
self.i2h = nn.Linear(input_size + hidden_size, hidden_size)
self.i2o = nn.Linear(input_size + hidden_size, output_size)
self.softmax = nn.LogSoftmax()
def forward(self, input, hidden):
combined = torch.cat((input, hidden), 1)
hidden = self.i2h(combined)
output = self.i2o(combined)
output = self.softmax(output)
return output, hidden
def init_hidden(self):
return Variable(torch.zeros(1, self.hidden_size))
此代码取自 Here。里面提到了
由于网络的状态保存在图表中而不是层中,您可以简单地创建一个 nn.Linear 并一遍又一遍地重复使用它。
我不明白的是,如何只增加 nn.Linear 中的输入特征大小并说它是 RNN。我在这里错过了什么?
【问题讨论】:
标签: python deep-learning pytorch recurrent-neural-network