|
使用 LSTM 神经网络进行时间序列预测的过程。下面我会对代码的主要部分进行解释: 定义 LSTM 网络:
# ]9 q, k* c: B; E7 q5 X8 k- lstm_reg 类继承自 nn.Module,它包含了一个 LSTM 层和一个线性层。
- 在 __init__ 方法中,定义了 LSTM 层和线性层的结构,其中 input_size 是输入样本的特征维度,hidden_size 是 LSTM 层的神经元个数,num_layers 是 LSTM 网络的层数。
- forward 方法实现了前向传播过程,将输入数据经过 LSTM 层和线性层得到输出。0 Z7 R, _, S# |! W) A( }/ f& k- l
创建预测数据集:
$ ^. T* u5 `0 v/ ], w2 E8 r- create_dataset 函数根据给定的数据集和滑动窗口大小创建预测的输入数据 data_X 和输出数据 data_Y。1 b+ C0 M. R7 R& l8 R
划分和重塑数据集:
3 ]( M! u6 O; @- split_reshape_dataset 函数将数据集划分为训练集和测试集,并将数据集的形状调整为适应 LSTM 网络的输入。
- 设置一个分割系数,默认为 0.7,即将数据集的前 70% 作为训练集,后 30% 作为测试集。
- look_back 参数是滑动窗口的大小,决定了输入特征的维度。' f, M; g! y2 Y! x# ]. S) c3 J/ B
数据预处理:
/ f7 E4 n. B8 F! `* x- data_preprocessing 函数对数据集进行预处理,包括丢弃空值和将数据归一化。
+ X2 m" N) ]- v
构建和训练 LSTM 网络: 3 Z" ^* p7 F2 p6 M4 \$ o+ d4 s8 \0 C
- 使用给定的参数创建 net 对象,即 LSTM 网络。
- 定义损失函数 criterion 和优化器 optimizer。
- 使用训练集进行训练,根据损失函数计算损失并通过优化器更新网络权重。
* M+ z3 r5 Q1 J3 o, N
加载已经训练好的模型: : g H, K7 L/ o W) i0 ]. L, [- i u
- 使用 torch.load 加载之前保存的模型参数文件。
3 h" w% Y: L; S2 X" @8 J
进行预测:
9 z' k2 \. ]0 U) s8 E4 x2 @# s- 使用测试集数据进行预测,将预测结果经过逆归一化处理得到真实值。
- 使用 Matplotlib 绘制真实值和预测值的曲线图。6 R: }4 G6 u7 P6 J+ I# j% M
计算 MSE 损失: , y: {1 t" L' O6 S8 m
- 将真实值和预测值之间的差平方,再求平均得到 MSE 损失。
5 n3 a$ h8 \/ P- a7 h: j
这段代码可以根据给定的数据集进行时间序列预测,并计算预测结果的 MSE 损失。
# ?, n0 C+ P' J6 J" n7 L0 X
) e6 U3 o, k% V t7 m, k6 Z
7 i: _& l! \$ a, ], c' N3 z9 J4 F$ ^
7 s6 [0 p; F) W4 Y. \ |