|
使用 LSTM 神经网络进行时间序列预测的过程。下面我会对代码的主要部分进行解释: 定义 LSTM 网络:
/ o2 I8 G G5 l$ P- lstm_reg 类继承自 nn.Module,它包含了一个 LSTM 层和一个线性层。
- 在 __init__ 方法中,定义了 LSTM 层和线性层的结构,其中 input_size 是输入样本的特征维度,hidden_size 是 LSTM 层的神经元个数,num_layers 是 LSTM 网络的层数。
- forward 方法实现了前向传播过程,将输入数据经过 LSTM 层和线性层得到输出。+ p5 O# z+ C: }, \- [. e+ z
创建预测数据集:
1 N* Y0 m+ g% u9 c" i% S- create_dataset 函数根据给定的数据集和滑动窗口大小创建预测的输入数据 data_X 和输出数据 data_Y。4 P ~0 @: }/ {6 t% ^2 E
划分和重塑数据集:
" x7 h' J# |6 |& r" p1 N- split_reshape_dataset 函数将数据集划分为训练集和测试集,并将数据集的形状调整为适应 LSTM 网络的输入。
- 设置一个分割系数,默认为 0.7,即将数据集的前 70% 作为训练集,后 30% 作为测试集。
- look_back 参数是滑动窗口的大小,决定了输入特征的维度。
: X1 l+ O% a# v% e( c+ u1 C' E
数据预处理:
, {7 g# i) g7 q+ y$ S- data_preprocessing 函数对数据集进行预处理,包括丢弃空值和将数据归一化。
# c' |/ ~% F2 R- T" C
构建和训练 LSTM 网络:
# F* @9 ]* B% j, F% t% v- 使用给定的参数创建 net 对象,即 LSTM 网络。
- 定义损失函数 criterion 和优化器 optimizer。
- 使用训练集进行训练,根据损失函数计算损失并通过优化器更新网络权重。$ T ?6 S# B$ A5 T3 o2 X% }
加载已经训练好的模型: ; E1 x( j* @) r( X, m
- 使用 torch.load 加载之前保存的模型参数文件。
: D+ T2 a* l& I* \
进行预测:
9 s+ g/ j7 x3 h+ H. m0 [* C. _2 t$ h- 使用测试集数据进行预测,将预测结果经过逆归一化处理得到真实值。
- 使用 Matplotlib 绘制真实值和预测值的曲线图。7 E0 C' l1 y7 }6 f& ~
计算 MSE 损失:
- b; g% U3 n& y# ?$ f# D. l- 将真实值和预测值之间的差平方,再求平均得到 MSE 损失。
/ I( y: R$ B$ k2 Z7 ^
这段代码可以根据给定的数据集进行时间序列预测,并计算预测结果的 MSE 损失。 : a+ R- T7 p) Q0 x* Z) J
, D3 v% \% [: I5 J6 Q9 A1 Z0 ]5 o6 s2 x4 P1 h
* r$ T3 V; a2 g8 I( T* w# k
|