【MATLAB第13期】基于LSTM长短期记忆网络的多输入单输出滑动窗口回归预测模型

【MATLAB第13期】基于LSTM长短期记忆网络的多输入单输出滑动窗口回归预测模型

MATLAB长短期记忆网络的多输入单输出滑动窗口回归预测

一、实现效果

往期文章提到了对单列时间序列数据进行滑动窗口处理的思路,本文介绍如何对多输入单输出数据进行滑动窗口的思路。实现效果如下:

在这里插入图片描述

训练过程
在这里插入图片描述
测试集拟合效果

二、数据设置:

198行(代表198天),21列数据,其中前20列为变量,第21列为因变量。
前80%数据训练,后20%数据测试

三、滑动窗口处理:

滑动窗口尺寸为7,即可认为前7天的变量作为输入,第7天的因变量作为输出。
则输入的一组样本矩阵结构由20×1变成 20×7
而样本数量也从原来的198变为192 ,因为前6组变量数据作为了历史样本
在这里插入图片描述
输入数据样本 20198
在这里插入图片描述
转变后 192
20*7

四、评价指标:

RMSE = 1.1891
MAPE = 0.05319

五、部分代码:

%% LSTM 多变量单输入滑动窗口处理
clear all;
clc;
close all;
load data

% 数据处理
% 归一化(全部特征 均归一化)
output_data =data(:,end);
input_data =data(:,1:end-1);
[input_normdata,input_normopt] =mapminmax(input_data',0,1);
[output_normdata,output_normopt] = mapminmax(output_data',0,1);
k =7;          %滑动窗口处理                                                    
% 划分数据集
n = floor(0.8*size(input_normdatacell,1));%训练集,测试集样本数目划分
% LSTM 层设置,参数设置
numhidden_units1=100;
% lstm
layers = [ ...
    sequenceInputLayer(inputSize,'name','input')                             %输入层设置
 lstmLayer(numhidden_units1)                     %学习层设置
     fullyConnectedLayer(outputSize,'name','fullconnect')                     %全连接层设置(outputsize:预测值的特征维度)
    regressionLayer('name','out')];                                          %回归层
% trainoption
opts = trainingOptions('adam', ...        %优化算法
    'MaxEpochs',10, ...                   %遍历样本最大循环数
    'GradientThreshold',1,...             %梯度阈值
    'ExecutionEnvironment','cpu',...      %运算环境
    'InitialLearnRate',0.001, ...         %初始学习率
    'Plots','training-progress'...        % 打印训练进度
    );
% 网络训练
tic
net = trainNetwork(input_xtraincell,output_ytraincell,layers,opts);      %网络训练
% 预测
                                                               %预测天数                                    
yprenorm = net.predict(input_xtestcell);   %预测
ypre = mapminmax('reverse',yprenorm',output_normopt);          %预测值反归一化
yytest = mapminmax('reverse',output_ytestcell',output_normopt); 
RMSE  = sqrt(mean((ypre-yytest).^2));
MAPE  = mean((ypre-yytest)./yytest);
disp(["RMSE2  ",RMSE ])
disp(["MAPE2 ", MAPE])

六、获取方式:

后台私信回复‘13期’,即可获取下载链接。

  • 4
    点赞
  • 51
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 18
    评论
LSTM(Long Short-Term Memory)是一种常用的循环神经网络,它的主要特点是可以对输入数据的长时依赖性进行建模,因此能够处理不定长的序列数据。在LSTM网络中,有三个门(输入门、遗忘门和输出门)用来控制信息的流动,以及一个状态变量来储存上一个时间步的记忆状态。这些门和状态变量能够有效地处理梯度消失/爆炸的问题,从而提高网络的训练效率和泛化能力。 针对LSTM网络的多输入输出问题,可以使用Matlab来进行实现。首先需要定义网络的结构,具体包括输入层、LSTM层和输出层。在输入层中,可以设置多个输入变量,以便将不同类型的数据输入网络。对于每个输入变量,需要设定其输入数据的维度和名称。在LSTM层中,需要指定网络的隐状态的节点数和时间步数。在输出层中,可以根据实际需要选择不同类型的激活函数,例如sigmoid函数、ReLU函数等。此外,还需要定义损失函数和优化器,以便进行网络的训练和优化。 在实现过程中,需要注意LSTM网络的参数初始化、学习率的设置、梯度裁剪等问题,以避免出现梯度消失/爆炸等问题。可以使用Matlab自带的深度学习工具箱,或者借助第三方工具库,例如Keras、PyTorch等。通过合理的参数调整和网络结构设计,可以得到较好的实验效果,从而实现LSTM网络的多输入输出任务。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 18
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

随风飘摇的土木狗

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值