双向长短期记忆网络(Bi-LSTM)-多输入回归预测

目录

一、程序及算法内容介绍:

基本内容:

亮点与优势:

二、实际运行效果:

三、部分代码展示:

四、完整代码下载:


一、程序及算法内容介绍:

基本内容:

  • 本代码基于Matlab平台编译,使用双向长短期记忆网络(Bi-LSTM)进行多维数据回归预测

  • 输入训练的数据包含7个特征,1个响应值,即通过7个输入值预测1个输出值(多输入回归预测

  • 归一化训练数据,提升网络泛化性

  • 网络计算过程中,自动显示训练进度条,实时查看程序运行进展情况

  • 自动输出多种多样的的误差评价指标,自动输出大量实验效果图片

亮点与优势:

  • 注释详细,几乎每一关键行都有注释说明,适合小白起步学习

  • 直接运行Main函数即可看到所有结果,使用便捷

  • 编程习惯良好,程序主体标准化,逻辑清晰,方便阅读代码

  • 所有数据均采用Excel格式输入,替换数据方便,适合懒人选手

  • 出图详细、丰富、美观,可直观查看运行效果

  • 附带详细的说明文档,其内容包括:算法原理+使用方法说明

二、实际运行效果:

 三、部分代码展示:


clear;
warning off;
%% 导入数据
Data = table2array(readtable("数据集.xlsx"));
% 本例数据集中包含:
% 1. 总共103个样本(每一行表示一个样本)
% 2. 每个样本7个特征值(即前7列每一列表示样本的一个特征,即输入的变量)
% 3. 每个样本1个响应值(第8列为表示样本的响应值,即被预测的变量)

%% 划分训练集和测试集
Temp = randperm(size(Data,1)); % 打乱数据的顺序,提升模型的泛化性。
InPut_num = 1:1:7; % 输入特征个数,数据表格中前7列为输入值,因此设置为1:1:7,若前5个为输入则设置为1:1:5
OutPut_num = 8; % 输出响应个数,本例仅一个响应值,为数据表格中第8个,若多个响应值参照上行数据格式设置为x:1:y

% 选取前80个样本作为训练集,后23个样本作为测试集,即(1:80),和(81:end)
Train_InPut = Data(Temp(1:80),InPut_num); % 训练输入
Train_OutPut = Data(Temp(1:80),OutPut_num); % 训练输出
Test_InPut = Data(Temp(81:end),InPut_num); % 测试输入
Test_OutPut = Data(Temp(81:end),OutPut_num); % 测试输出
clear Temp;
%% 数据归一化
% 将输入特征数据归一化到0-1之间
[~, Ps.Input] = mapminmax([Train_InPut;Test_InPut]',0,1); 
Train_InPut = mapminmax('apply',Train_InPut',Ps.Input);
Test_InPut = mapminmax('apply',Test_InPut',Ps.Input);
% 将输出响应数据归一化到0-1之间
[~, Ps.Output] = mapminmax([Train_OutPut;Test_OutPut]',0,1);
Train_OutPut = mapminmax('apply',Train_OutPut',Ps.Output);
Test_OutPut = mapminmax('apply',Test_OutPut',Ps.Output);
Temp_TrI = cell(size(Train_InPut,2),1);
Temp_TrO = cell(size(Train_OutPut,2),1);
Temp_TeI = cell(size(Test_InPut,2),1);
Temp_TeO = cell(size(Test_OutPut,2),1);

四、完整代码下载:

  • 8
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Bi-LSTM双向长短期记忆网络)是一种循环神经网络(RNN)的变体,它在处理序列数据时能够同时考虑过去和未来的信息。与传统的单向LSTM不同,Bi-LSTM包含两个LSTM结构:一个正向LSTM和一个反向LSTM。正向LSTM按照时间顺序处理输入序列,而反向LSTM按照时间逆序处理输入序列。两个LSTM的输出被连接起来,形成Bi-LSTM的最终输出。 Bi-LSTM网络结构如下图所示: ``` 正向LSTM输入Bi-LSTM → 输出 ↓ 反向LSTM ``` Bi-LSTM的计算过程与单个LSTM类似,但它能够捕捉输入数据双向的依赖信息,从而提高了模型对输入数据的特征表达能力。在需求预测回归问题中,Bi-LSTM可以根据过去的记录预测未来的需求。 以下是一个使用Bi-LSTM进行需求预测的示例代码: ```python import tensorflow as tf from tensorflow.keras.models import Sequential from tensorflow.keras.layers import LSTM, Dense, Bidirectional # 构建Bi-LSTM模型 model = Sequential() model.add(Bidirectional(LSTM(64, activation='relu'), input_shape=(timesteps, input_dim))) model.add(Dense(1)) # 编译模型 model.compile(optimizer='adam', loss='mse') # 训练模型 model.fit(X_train, y_train, epochs=10, batch_size=32) # 预测未来需求 predictions = model.predict(X_test) ``` 在上述代码中,我们使用了TensorFlow和Keras库来构建Bi-LSTM模型。首先,我们定义了一个Sequential模型,并添加了一个Bidirectional层,其中包含一个LSTM层。输入数据的形状为(timesteps, input_dim),其中timesteps表示过去记录的数量,input_dim表示每个记录的特征数量。然后,我们添加了一个Dense层作为输出层。模型使用均方误差(MSE)作为损失函数,并使用Adam优化器进行训练。最后,我们使用训练好的模型对未来的需求进行预测

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值