当前位置: 首页 > news >正文

(Matalb时序预测)PSO-BP粒子群算法优化BP神经网络的多维时序回归预测

目录

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

基本内容:

亮点与优势:

 二、实际运行效果:

 三、部分程序:

 四、完整程序+数据+说明文档下载:


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

基本内容:

  • 本代码基于Matalb平台编译,将PSO(粒子群算法)与BP神经网络结合,进行数据时序回归预测

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

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

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

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

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

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

亮点与优势:

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

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

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

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

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

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

 二、实际运行效果:

 三、部分程序:

clc;
clear;
warning off;
%% 导入数据
Data = table2array(readtable("数据集.xlsx"));
% 本例数据集中包含:
% 1. 总共472个样本(每一行表示一个样本)
% 2. 每个样本8个特征值(即前8列每一列表示样本的一个特征,即输入的变量)
% 3. 每个样本1个响应值(第9列为表示样本的响应值,即被预测的变量)%% 划分训练集和测试集
InPut_num = 1:1:8; % 输入特征个数,数据表格中前8列为输入值,因此设置为1:1:8,若前5个为输入则设置为1:1:5
OutPut_num = 9; % 输出响应个数,本例仅一个响应值,为数据表格中第9个,若多个响应值参照上行数据格式设置为x:1:y% 选取前376个样本作为训练集,后96个样本作为测试集,即(1:376),和(377:end)
Train_InPut = Data(1:376,InPut_num); % 训练输入
Train_OutPut = Data(1:376,OutPut_num); % 训练输出
Test_InPut = Data(377:end,InPut_num); % 测试输入
Test_OutPut = Data(377:end,OutPut_num); % 测试输出%% 数据归一化
% 将数据归一化到0-1之间
Temp = [Train_OutPut;Test_OutPut];
[~, Ps] = mapminmax(Temp',0,1); 
% 归一化训练输入值
Sc = size(Train_InPut);
Temp = reshape(Train_InPut,[1,Sc(1)*Sc(2)]);
Temp = mapminmax('apply',Temp,Ps);
Train_InPut = reshape(Temp,[Sc(1),Sc(2)])';
% 归一化测试输入值
Sc = size(Test_InPut);
Temp = reshape(Test_InPut,[1,Sc(1)*Sc(2)]);
Temp = mapminmax('apply',Temp,Ps);
Test_InPut = reshape(Temp,[Sc(1),Sc(2)])';
% 归一化训练输出值
Train_OutPut = mapminmax('apply',Train_OutPut',Ps);
% 归一化测试输出值
Test_OutPut = mapminmax('apply',Test_OutPut',Ps);

 四、完整程序+数据+说明文档下载:

 

相关文章:

  • Java SPI机制
  • 【服务器学习】timer定时器模块
  • mac环境使用sudo进行node包管理
  • 矩阵的QR分解
  • sqli-labs关卡18(基于http头部报错盲注)通关思路
  • react 手机端 rc-table列隐藏(根据相关条件是否隐藏)、实现图片上传操作
  • 矩阵的模和内积
  • 基于金鹰算法优化概率神经网络PNN的分类预测 - 附代码
  • 量化交易:借助talib使用技术分析指标
  • Python字典六种类型概述
  • 和解电话(匿名电话)/情侣拉黑联系电话/虚拟号/虚拟中间号/拉黑联系项目代码
  • 直流电机干扰的产生-EMC和EMI
  • Linux的简单使用
  • ATTCK实战系列——红队实战(一)
  • 生成对抗网络(GAN)
  • 网络传输文件的问题
  • create-react-app项目添加less配置
  • ES6核心特性
  • HTML中设置input等文本框为不可操作
  • JavaScript设计模式系列一:工厂模式
  • java中的hashCode
  • Laravel核心解读--Facades
  • maya建模与骨骼动画快速实现人工鱼
  • nodejs:开发并发布一个nodejs包
  • python 学习笔记 - Queue Pipes,进程间通讯
  • python大佬养成计划----difflib模块
  • ReactNativeweexDeviceOne对比
  • React组件设计模式(一)
  • Selenium实战教程系列(二)---元素定位
  • SpiderData 2019年2月25日 DApp数据排行榜
  • spring boot下thymeleaf全局静态变量配置
  • 从伪并行的 Python 多线程说起
  • 订阅Forge Viewer所有的事件
  • 基于Volley网络库实现加载多种网络图片(包括GIF动态图片、圆形图片、普通图片)...
  • 前端相关框架总和
  • 使用 5W1H 写出高可读的 Git Commit Message
  • 使用 QuickBI 搭建酷炫可视化分析
  • 思维导图—你不知道的JavaScript中卷
  • 探索 JS 中的模块化
  • 微信如何实现自动跳转到用其他浏览器打开指定页面下载APP
  • 原生 js 实现移动端 Touch 滑动反弹
  • “十年磨一剑”--有赞的HBase平台实践和应用之路 ...
  • 国内开源镜像站点
  • # 日期待t_最值得等的SUV奥迪Q9:空间比MPV还大,或搭4.0T,香
  • #!/usr/bin/python与#!/usr/bin/env python的区别
  • #Lua:Lua调用C++生成的DLL库
  • #周末课堂# 【Linux + JVM + Mysql高级性能优化班】(火热报名中~~~)
  • $.ajax中的eval及dataType
  • (2/2) 为了理解 UWP 的启动流程,我从零开始创建了一个 UWP 程序
  • (Arcgis)Python编程批量将HDF5文件转换为TIFF格式并应用地理转换和投影信息
  • (day6) 319. 灯泡开关
  • (floyd+补集) poj 3275
  • (顶刊)一个基于分类代理模型的超多目标优化算法
  • (多级缓存)多级缓存
  • (论文阅读40-45)图像描述1