【时序预测 】基于贝叶斯优化卷积神经网络-长短期记忆网络BO-CNN-LSTM实现股价预测附matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。

🍎个人主页:Matlab科研工作室

🍊个人信条:格物致知。

更多Matlab仿真内容点击👇

智能优化算法       神经网络预测       雷达通信       无线传感器        电力系统

信号处理              图像处理               路径规划       元胞自动机        无人机 

⛄ 内容介绍

为提高股价估算或预测准确性和适应性,本文提出了一种基于贝叶斯网络卷积神经网络(Convolutional Neural Network, CNN)和门控循环单元(gated recurrent unit, GRU)的股价预测方法.首先,利用数据采集与监视控制系统获取股价数据进行预处理.其次,将预处理后的海量数据按时间滑动窗口构造为连续的特征矩阵作为输入,然后利用贝叶斯网络优化模型参数,最后利用CNN-GRU混合模型建立输入特征与股价的映射关系,生成基于BO-CNN-GRU中股价预测模型,进而实现其回归预测.验证了所提的模型具有较高的准确性和可行性,相关结论与讨论对配电网智能化技术研发有一定参考价值.

⛄ 部分代码

clc;clear;close all;  train_y_feature_label=y_feature_label1(index_label(1:train_num),:); 

 vaild_y_feature_label=y_feature_label1(index_label(train_num+1:vaild_num),:);

 test_y_feature_label=y_feature_label1(index_label(vaild_num+1:end),:);

%%

train_y=train_y_feature_label;  train_y(find(train_y==0))=0.1;  %防止分母为0 

train_MAE=sum(sum(abs(y_train_predict-train_y)))/size(train_y,1)/size(train_y,2) ; disp(['训练集平均绝对误差MAE:',num2str(train_MAE)])

train_MAPE=sum(sum(abs((y_train_predict-train_y)./train_y)))/size(train_y,1)/size(train_y,2); disp(['训练集平均相对误差MAPE:',num2str(train_MAPE)])

train_MSE=(sum(sum(((y_train_predict-train_y)).^2))/size(train_y,1)/size(train_y,2)); disp(['训练集均方根误差MSE:',num2str(train_MSE)])     

train_RMSE=sqrt(sum(sum(((y_train_predict-train_y)).^2))/size(train_y,1)/size(train_y,2)); disp(['训练集均方根误差RMSE:',num2str(train_RMSE)]) 

train_R2 = 1 - mean(norm(train_y - y_train_predict)^2 / norm(train_y - mean(train_y))^2);   disp(['训练集均方根误差R2:',num2str(train_R2)]) 

vaild_y=vaild_y_feature_label;vaild_y(find(vaild_y==0))=0.1;  %防止分母为0 

vaild_MAE=sum(sum(abs(y_vaild_predict-vaild_y)))/size(vaild_y,1)/size(vaild_y,2) ; disp(['验证集平均绝对误差MAE:',num2str(vaild_MAE)])

vaild_MAPE=sum(sum(abs((y_vaild_predict-vaild_y)./vaild_y)))/size(vaild_y,1)/size(vaild_y,2); disp(['验证集平均相对误差MAPE:',num2str(vaild_MAPE)])

vaild_MSE=(sum(sum(((y_vaild_predict-vaild_y)).^2))/size(vaild_y,1)/size(vaild_y,2)); disp(['验证集均方根误差MSE:',num2str(vaild_MSE)])     

vaild_RMSE=sqrt(sum(sum(((y_vaild_predict-vaild_y)).^2))/size(vaild_y,1)/size(vaild_y,2)); disp(['验证集均方根误差RMSE:',num2str(vaild_RMSE)]) 

vaild_R2 = 1 - mean(norm(vaild_y - y_vaild_predict)^2 / norm(vaild_y - mean(vaild_y))^2);   disp(['验证集均方根误差R2:',num2str(vaild_R2)]) 

test_y=test_y_feature_label;test_y(find(test_y==0))=0.1;  %防止分母为0 

test_MAE=sum(sum(abs(y_test_predict-test_y)))/size(test_y,1)/size(test_y,2) ; disp(['测试集平均绝对误差MAE:',num2str(test_MAE)])

test_MAPE=sum(sum(abs((y_test_predict-test_y)./test_y)))/size(test_y,1)/size(test_y,2); disp(['测试集平均相对误差MAPE:',num2str(test_MAPE)])

test_MSE=(sum(sum(((y_test_predict-test_y)).^2))/size(test_y,1)/size(test_y,2)); disp(['测试集均方根误差MSE:',num2str(test_MSE)])     

test_RMSE=sqrt(sum(sum(((y_test_predict-test_y)).^2))/size(test_y,1)/size(test_y,2)); disp(['测试集均方根误差RMSE:',num2str(test_RMSE)]) 

test_R2 = 1 - mean(norm(test_y - y_test_predict)^2 / norm(test_y - mean(test_y))^2);   disp(['测试集均方根误差R2:',num2str(test_R2)]) 

%%

figure;

num=12;

if num>size(test_y,2)

    num=size(test_y,2);

end

plot(test_y(:,num))

hold on

plot(y_test_predict(:,num))

legend('True','predict')

⛄ 运行结果

⛄ 参考文献

[1] 罗  勇, 荣  娜, 詹献文. 基于CNN-GRU的配电网中压馈线合环电流预测研究[J]. 应用数学进展, 2022, 11(7):17.

[2] 史玉良, 陈智智, 张坤. 基于GRU优化用电信息采集终端故障预测模型的方法及系统:, CN110335168A[P]. 2019.

[3] 李鸿雁, 苏庭波. 基于贝叶斯网络和卷积神经网络的手绘草图识别方法[J]. 西南师范大学学报:自然科学版, 2019, 44(9):7.

[4] 曾蔚, 吴伊萍. 一种基于卷积神经网络和贝叶斯网络的用户行为预测算法[J]. 安阳师范学院学报, 2019(2):6.

[5] 周洁超. 基于贝叶斯网络的时间序列预测[D]. 大连海事大学, 2016.

⛳️ 代码获取关注我

❤️部分理论引用网络文献,若有侵权联系博主删除

❤️ 关注我领取海量matlab电子书和数学建模资料

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

matlab科研助手

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

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

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

打赏作者

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

抵扣说明:

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

余额充值