700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > PyTorch搭建LSTM实现多变量多步长时间序列预测(一):直接多输出

PyTorch搭建LSTM实现多变量多步长时间序列预测(一):直接多输出

时间:2024-02-23 20:50:56

相关推荐

PyTorch搭建LSTM实现多变量多步长时间序列预测(一):直接多输出

目录

I. 前言II. 数据处理III. LSTM模型IV. 训练和预测V. 源码及数据

I. 前言

在前面的两篇文章PyTorch搭建LSTM实现时间序列预测(负荷预测)和PyTorch搭建LSTM实现多变量时间序列预测(负荷预测)中,我们利用LSTM分别实现了单变量单步长时间序列预测和多变量单步长时间序列预测。

本篇文章主要考虑用PyTorch搭建LSTM实现多变量多步长时间序列预测。

系列文章:

深入理解PyTorch中LSTM的输入和输出(从input输入到Linear输出)PyTorch搭建LSTM实现时间序列预测(负荷预测)PyTorch搭建LSTM实现多变量时间序列预测(负荷预测)PyTorch搭建双向LSTM实现时间序列预测(负荷预测)PyTorch搭建LSTM实现多变量多步长时间序列预测(一):直接多输出PyTorch搭建LSTM实现多变量多步长时间序列预测(二):单步滚动预测PyTorch搭建LSTM实现多变量多步长时间序列预测(三):多模型单步预测PyTorch搭建LSTM实现多变量多步长时间序列预测(四):多模型滚动预测PyTorch搭建LSTM实现多变量多步长时间序列预测(五):seq2seqPyTorch中实现LSTM多步长时间序列预测的几种方法总结(负荷预测)PyTorch-LSTM时间序列预测中如何预测真正的未来值PyTorch搭建LSTM实现多变量输入多变量输出时间序列预测(多任务学习)PyTorch搭建ANN实现时间序列预测(风速预测)PyTorch搭建CNN实现时间序列预测(风速预测)PyTorch搭建CNN-LSTM混合模型实现多变量多步长时间序列预测(负荷预测)PyTorch搭建Transformer实现多变量多步长时间序列预测(负荷预测)PyTorch时间序列预测系列文章总结(代码使用方法)TensorFlow搭建LSTM实现时间序列预测(负荷预测)TensorFlow搭建LSTM实现多变量时间序列预测(负荷预测)TensorFlow搭建双向LSTM实现时间序列预测(负荷预测)TensorFlow搭建LSTM实现多变量多步长时间序列预测(一):直接多输出TensorFlow搭建LSTM实现多变量多步长时间序列预测(二):单步滚动预测TensorFlow搭建LSTM实现多变量多步长时间序列预测(三):多模型单步预测TensorFlow搭建LSTM实现多变量多步长时间序列预测(四):多模型滚动预测TensorFlow搭建LSTM实现多变量多步长时间序列预测(五):seq2seqTensorFlow搭建LSTM实现多变量输入多变量输出时间序列预测(多任务学习)TensorFlow搭建ANN实现时间序列预测(风速预测)TensorFlow搭建CNN实现时间序列预测(风速预测)TensorFlow搭建CNN-LSTM混合模型实现多变量多步长时间序列预测(负荷预测)

II. 数据处理

数据集为某个地区某段时间内的电力负荷数据,除了负荷以外,还包括温度、湿度等信息。

本文中,我们根据前24个时刻的负荷以及该时刻的环境变量来预测接下来4个时刻的负荷(步长可调)。

任意输出其中一条数据:

(tensor([[0.5830, 1.0000, 0.9091, 0.6957, 0.8333, 0.4884, 0.5122],[0.6215, 1.0000, 0.9091, 0.7391, 0.8333, 0.4884, 0.5122],[0.5954, 1.0000, 0.9091, 0.7826, 0.8333, 0.4884, 0.5122],[0.5391, 1.0000, 0.9091, 0.8261, 0.8333, 0.4884, 0.5122],[0.5351, 1.0000, 0.9091, 0.8696, 0.8333, 0.4884, 0.5122],[0.5169, 1.0000, 0.9091, 0.9130, 0.8333, 0.4884, 0.5122],[0.4694, 1.0000, 0.9091, 0.9565, 0.8333, 0.4884, 0.5122],[0.4489, 1.0000, 0.9091, 1.0000, 0.8333, 0.4884, 0.5122],[0.4885, 1.0000, 0.9091, 0.0000, 1.0000, 0.3256, 0.3902],[0.4612, 1.0000, 0.9091, 0.0435, 1.0000, 0.3256, 0.3902],[0.4229, 1.0000, 0.9091, 0.0870, 1.0000, 0.3256, 0.3902],[0.4173, 1.0000, 0.9091, 0.1304, 1.0000, 0.3256, 0.3902],[0.4503, 1.0000, 0.9091, 0.1739, 1.0000, 0.3256, 0.3902],[0.4502, 1.0000, 0.9091, 0.2174, 1.0000, 0.3256, 0.3902],[0.5426, 1.0000, 0.9091, 0.2609, 1.0000, 0.3256, 0.3902],[0.5579, 1.0000, 0.9091, 0.3043, 1.0000, 0.3256, 0.3902],[0.6035, 1.0000, 0.9091, 0.3478, 1.0000, 0.3256, 0.3902],[0.6540, 1.0000, 0.9091, 0.3913, 1.0000, 0.3256, 0.3902],[0.6181, 1.0000, 0.9091, 0.4348, 1.0000, 0.3256, 0.3902],[0.6334, 1.0000, 0.9091, 0.4783, 1.0000, 0.3256, 0.3902],[0.6297, 1.0000, 0.9091, 0.5217, 1.0000, 0.3256, 0.3902],[0.5610, 1.0000, 0.9091, 0.5652, 1.0000, 0.3256, 0.3902],[0.5957, 1.0000, 0.9091, 0.6087, 1.0000, 0.3256, 0.3902],[0.6427, 1.0000, 0.9091, 0.6522, 1.0000, 0.3256, 0.3902]]), tensor([0.6360, 0.6996, 0.6889, 0.6434]))

数据格式为(X, Y)。其中X一共24行,表示前24个时刻的负荷值和该时刻的环境变量。Y一共四个值,表示需要预测的四个负荷值。需要注意的是,此时input_size=7,output_size=4

III. LSTM模型

这里采用了深入理解PyTorch中LSTM的输入和输出(从input输入到Linear输出)中的模型:

class LSTM(nn.Module):def __init__(self, input_size, hidden_size, num_layers, output_size, batch_size):super().__init__()self.input_size = input_sizeself.hidden_size = hidden_sizeself.num_layers = num_layersself.output_size = output_sizeself.num_directions = 1 # 单向LSTMself.batch_size = batch_sizeself.lstm = nn.LSTM(self.input_size, self.hidden_size, self.num_layers, batch_first=True)self.linear = nn.Linear(self.hidden_size, self.output_size)def forward(self, input_seq):batch_size, seq_len = input_seq.shape[0], input_seq.shape[1]h_0 = torch.randn(self.num_directions * self.num_layers, self.batch_size, self.hidden_size).to(device)c_0 = torch.randn(self.num_directions * self.num_layers, self.batch_size, self.hidden_size).to(device)# output(batch_size, seq_len, num_directions * hidden_size)output, _ = self.lstm(input_seq, (h_0, c_0)) # output(5, 30, 64)pred = self.linear(output) # (5, 30, 1)pred = pred[:, -1, :] # (5, 1)return pred

IV. 训练和预测

训练和预测代码和前几篇都差不多,只是需要注意input_size和output_size的大小。

训练了50轮,预测接下来4个时刻的负荷值,MAPE为7.62%:

V. 源码及数据

后面将陆续公开~

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。