• (Matalb时序预测)WOA-BP鲸鱼算法优化BP神经网络的多维时序回归预测


    目录

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

    基本内容:

    亮点与优势:

     二、实际运行效果:

    三、部分代码:

    四、完整代码+数据+说明手册:


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

    基本内容:

    • 本代码基于Matalb平台编译,将WOA(鲸鱼算法)与BP神经网络结合,进行数据回归预测

    • 输入训练的数据包含8个特征,1个响应值,即通过8个输入值预测1个输出值(多变量时序预测)

    • 归一WOA算法优化BP神经网络的初始权重、初始偏差等参数,记录下最优的网络参数

    • 训练BP网络进行时序回归预测,将优化前后的网络预测效果进行对比,突出优化的重要性

    • 迭代计算过程中,自动显示优化进度条,实时查看程序运行进展情况

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

    亮点与优势:

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

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

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

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

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

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

     二、实际运行效果:

    三、部分代码:

    1. clc;
    2. clear;
    3. warning off;
    4. %% 导入数据
    5. Data = table2array(readtable("数据集.xlsx"));
    6. % 本例数据集中包含:
    7. % 1. 总共472个样本(每一行表示一个样本)
    8. % 2. 每个样本8个特征值(即前8列每一列表示样本的一个特征,即输入的变量)
    9. % 3. 每个样本1个响应值(第9列为表示样本的响应值,即被预测的变量)
    10. %% 划分训练集和测试集
    11. InPut_num = 1:1:8; % 输入特征个数,数据表格中前8列为输入值,因此设置为1:1:8,若前5个为输入则设置为1:1:5
    12. OutPut_num = 9; % 输出响应个数,本例仅一个响应值,为数据表格中第9个,若多个响应值参照上行数据格式设置为x:1:y
    13. % 选取前376个样本作为训练集,后96个样本作为测试集,即(1376),和(377end
    14. Train_InPut = Data(1:376,InPut_num); % 训练输入
    15. Train_OutPut = Data(1:376,OutPut_num); % 训练输出
    16. Test_InPut = Data(377:end,InPut_num); % 测试输入
    17. Test_OutPut = Data(377:end,OutPut_num); % 测试输出
    18. %% 数据归一化
    19. % 将数据归一化到0-1之间
    20. Temp = [Train_OutPut;Test_OutPut];
    21. [~, Ps] = mapminmax(Temp',0,1);
    22. % 归一化训练输入值
    23. Sc = size(Train_InPut);
    24. Temp = reshape(Train_InPut,[1,Sc(1)*Sc(2)]);
    25. Temp = mapminmax('apply',Temp,Ps);
    26. Train_InPut = reshape(Temp,[Sc(1),Sc(2)])';
    27. % 归一化测试输入值
    28. Sc = size(Test_InPut);
    29. Temp = reshape(Test_InPut,[1,Sc(1)*Sc(2)]);
    30. Temp = mapminmax('apply',Temp,Ps);
    31. Test_InPut = reshape(Temp,[Sc(1),Sc(2)])';
    32. % 归一化训练输出值
    33. Train_OutPut = mapminmax('apply',Train_OutPut',Ps);
    34. % 归一化测试输出值
    35. Test_OutPut = mapminmax('apply',Test_OutPut',Ps);

    四、完整代码+数据+说明手册:

  • 相关阅读:
    c++征途 -- 程序流程结构
    Java多线程之线程池(合理分配资源)
    不知道如何制作产品图册的,赶紧收藏住!
    Facebook广告账户被封?最全防封及申诉指南
    Docker
    【一起学Rust | 进阶篇 | Grid库】二维表数据结构——Grid
    【剪映专业版】13快速为视频配好音:清晰、无噪声、对齐
    使用tensorflow进行完整的DNN深度神经网络CNN训练完成图片识别案例
    大数据平台迁移后yarn连接zookeeper 异常分析
    护网(HVV)技术详解:网络安全演习的核心技能要求
  • 原文地址:https://blog.csdn.net/widhdbjf/article/details/134430024