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

(Matalb分类预测)GA-BP遗传算法优化BP神经网络的多维分类预测

目录

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

基本内容:

亮点与优势:

 二、实际运行效果:

三、部分代码:

四、本文代码+数据+说明手册分享


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

基本内容:

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

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

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

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

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

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

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

亮点与优势:

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

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

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

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

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

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

 二、实际运行效果:

三、部分代码:

clc;
clear;
warning off;
%% 导入数据
Data = table2array(readtable("数据集.xlsx"));
% 本例数据集中包含:
% 1. 总共357个样本(每一行表示一个样本)
% 2. 每个样本12个特征值(即前12列每一列表示样本的一个特征,即输入的变量)
% 3. 每个样本1个响应值(第13列为表示样本的响应值,即被预测的变量)%% 划分训练集和测试集
Temp = randperm(size(Data,1)); % 打乱数据的顺序,提升模型的泛化性。
InPut_num = 1:1:12; % 输入特征的列数,数据表格中前12列为输入值,因此设置为1:1:12,若前5个为输入则设置为1:1:5
OutPut_num = 13; % 输出响应列数,本例仅一个响应值,为数据表格中第13列,若多个响应值参照上行数据格式设置为x:1:y% 选取前327个样本作为训练集,后30个样本作为测试集,即(1:327),和(328:end)
Train_InPut = Data(Temp(1:327),InPut_num); % 训练输入
Train_OutPut = Data(Temp(1:327),OutPut_num); % 训练输出
Test_InPut = Data(Temp(328:end),InPut_num); % 测试输入
Test_OutPut = Data(Temp(328:end),OutPut_num); % 测试输出%% 数据归一化
% 将输入特征数据归一化到0-1之间
[~, Ps] = mapminmax([Train_InPut;Test_InPut]',0,1); 
Train_InPut = mapminmax('apply',Train_InPut',Ps);
Test_InPut = mapminmax('apply',Test_InPut',Ps);
% 输出可不用归一化,转置后设置为分类变量即可
Train_OutPut = ind2vec(Train_OutPut');
Test_OutPut = ind2vec(Test_OutPut');

四、本文代码+数据+说明手册分享

相关文章:

  • Android Gradle 升级到7.x及Maven推送问题
  • 【Go语言从入门到实战】反射编程、Unsafe篇
  • 数据结构 / 结构体指针
  • [Docker]十一.Docker Swarm集群raft算法,Docker Swarm Web管理工具
  • VMware共享文件夹不能放mysql的数据
  • Centos 7 环境下 PostgreSQL 生产环境优化
  • C#,数值计算——有理函数插值和外推(Rational_interp)的计算方法与源程序
  • java io 流,输入流和输出流;节点流和处理流;字节流和字符流
  • 基于ncurse实现的俄罗斯方块
  • (附源码)SSM环卫人员管理平台 计算机毕设36412
  • 04 _ 系统设计目标(二):系统怎样做到高可用?
  • 快速认识Linux的几个指令
  • hadoop2.x linux集群部署
  • MySQL 库操作 | 表操作
  • 项目管理套路:看这一篇绝对够用❤️
  • Laravel Mix运行时关于es2015报错解决方案
  • miniui datagrid 的客户端分页解决方案 - CS结合
  • Protobuf3语言指南
  • supervisor 永不挂掉的进程 安装以及使用
  • Vim 折腾记
  • vue和cordova项目整合打包,并实现vue调用android的相机的demo
  • - 概述 - 《设计模式(极简c++版)》
  • 解析带emoji和链接的聊天系统消息
  • 每天一个设计模式之命令模式
  • 如何利用MongoDB打造TOP榜小程序
  • 系统认识JavaScript正则表达式
  • 应用生命周期终极 DevOps 工具包
  • 硬币翻转问题,区间操作
  • 正则表达式小结
  • ​Linux·i2c驱动架构​
  • ​如何防止网络攻击?
  • ​中南建设2022年半年报“韧”字当头,经营性现金流持续为正​
  • (阿里巴巴 dubbo,有数据库,可执行 )dubbo zookeeper spring demo
  • (安卓)跳转应用市场APP详情页的方式
  • (八)c52学习之旅-中断实验
  • (附源码)计算机毕业设计ssm本地美食推荐平台
  • (已解决)报错:Could not load the Qt platform plugin “xcb“
  • (转)ABI是什么
  • (转)编辑寄语:因为爱心,所以美丽
  • (转载)Linux 多线程条件变量同步
  • (转载)深入super,看Python如何解决钻石继承难题
  • .NET C#版本和.NET版本以及VS版本的对应关系
  • .NET 除了用 Task 之外,如何自己写一个可以 await 的对象?
  • .netcore 如何获取系统中所有session_如何把百度推广中获取的线索(基木鱼,电话,百度商桥等)同步到企业微信或者企业CRM等企业营销系统中...
  • .NET序列化 serializable,反序列化
  • .set 数据导入matlab,设置变量导入选项 - MATLAB setvaropts - MathWorks 中国
  • /dev/VolGroup00/LogVol00:unexpected inconsistency;run fsck manually
  • @Service注解让spring找到你的Service bean
  • @synthesize和@dynamic分别有什么作用?
  • @vue/cli脚手架
  • [ vulhub漏洞复现篇 ] Hadoop-yarn-RPC 未授权访问漏洞复现
  • [ 数据结构 - C++]红黑树RBTree
  • []AT 指令 收发短信和GPRS上网 SIM508/548
  • [20171102]视图v$session中process字段含义
  • [ACTF2020 新生赛]Include