【机器学习】BP神经网络Matlab实现

在这里插入图片描述

目录

    • 1.背景
    • 2.原理
    • 3.代码实现


1.背景

BP神经网络(Backpropagation Neural Network)是一种机器学习算法,其通过反向传播算法来训练网络,使其能够学习输入数据的模式并进行预测或分类任务。BP神经网络通常包括输入层、隐藏层和输出层,并使用反向传播算法来调整网络中的权重,以最小化预测结果与实际结果之间的误差。BP神经网络可以被归类为一种监督学习算法,用于解决各种机器学习问题,如回归、分类等。

2.原理

原理部分可见:
一文搞懂BP神经网络——从原理到应用

3.代码实现

案例:样本特征数为24,4分类问题。

%% 导入数据
data = xlsread("data.xlsx");
%% 划分训练集&测试集
[M, N] = size(data);
temp = randperm(M); %随机打乱 
P_train = data(temp(1:round(0.9*M)),1:N-1); %训练集
T_train = data(temp(1:round(0.9*M)),N);
P_test = data(temp(round(0.9*M)+1:end),1:N-1); %测试集
T_test = data(temp(round(0.9*M)+1:end),N);
%% 输入层、隐含层、输出层节点个数
inputnum=24; %输入层神经元个数
outputnum=4; %输出层神经元个数
hiddennum = 5; %隐藏层神经元个数
%% 归一化
[p_train,ps_train]=mapminmax(P_train',0,1);
p_test=mapminmax('apply',P_test',ps_train);
t_train = ind2vec(T_train'); %one-hot编码
t_test = ind2vec(T_test');
%% 设置网络参数
net=newff(p_train,t_train,hiddennum);  %构建BP神经网络
net.trainParam.epochs=1000; %训练次数
net.trainParam.goal=1e-6; %精度
net.trainParam.lr=0.01; %学习率
%% 训练
net = train(net,p_train,t_train);
%% 仿真
t_sim1 = sim(net,p_train);
t_sim2 = sim(net,p_test);
%% 反归一化
T_sim1 = vec2ind(t_sim1);
T_sim2 = vec2ind(t_sim2);
%% 性能评价
err1 = sum((T_sim1'==T_train))/1800*100;
err2 = sum((T_sim2'==T_test))/200*100;
[T_train,idx1] = sort(T_train);
[T_test,idx2] = sort(T_test);
T_sim1 = T_sim1(idx1);
T_sim2 = T_sim2(idx2);
%% 绘图
subplot(1,2,1)
plot(1:1800,T_train,'*-',1:1800,T_sim1,'o-');
legend('真实值','预测值');
title({'训练集';['准确率=' num2str(err1) '%']});
xlabel('预测样本');
ylabel('预测结果');subplot(1,2,2)
plot(1:200,T_test,'*-',1:200,T_sim2,'o-');
legend('真实值','预测值');
title({'测试集';['准确率=' num2str(err2) '%']});
xlabel('预测样本');
ylabel('预测结果');figure
cm = confusionchart(T_train,T_sim1);
cm.Title = '训练数据混淆矩阵';
cm.ColumnSummary = 'column-normalized';
cm.RowSummary = 'row-normalized';figure
cm = confusionchart(T_test,T_sim2);
cm.Title = '测试数据混淆矩阵';
cm.ColumnSummary = 'column-normalized';
cm.RowSummary = 'row-normalized';

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/564010.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Qt 压缩/解压文件

前面讲了很多Qt的文件操作,文件操作自然就包括压缩与解压缩文件了,正好最近项目里要用到压缩以及解压缩文件,所以就研究了一下Qt如何压缩与解压缩文件。 QZipReader/QZipWriter QZipReader 和 QZipWriter 类提供了用于读取和写入 ZIP 格式文…

前端面试笔记

目录 React特性生命周期useEffectrouter传参方式*注意点* HTTP请求状态码 HTML行内元素语义化H5新特性cookie,session,token前端性能优化XSSCSRFBEM命名规范 JS判断变量的类型作用域链事件委托闭包ES6新特性节流和防抖Promise遍历Map方法 CSS盒模型样式优…

2024-03-24 思考-MBTI-简要记录

摘要: 2024-03-24 思考-MBTI-简要记录 MBTI16型人格: MBTI16型人格在人格研究和评价中得到了广泛的应用。MBTI是一种基于瑞士心理学家荣格在理论基础上发展起来的人格分类工具。为了准确判断个人的心态偏好,将每个人分为16种不同的人格类型。这种分类方法不仅为我们…

知识管理入门:轻松选择合适的知识管理软件

你是不是经常觉得自己的大脑像个杂乱的仓库,各种信息、知识和想法在里面乱窜,找不到头绪?别担心,知识管理软件来帮你解决这个问题啦!今天,我们就来聊聊知识管理软件这个神奇的工具,新手也能轻松…

【详解】Java反射机制(打穿封装)

目录 定义: 用途: 反射基本信息: 反射相关的类(important): Class类(反射机制的起源 ) Class类中的相关方法: 常用获得类相关的方法(重要) 常用获得类中属性相关的…

【十六】MySQL数据库设计篇

MySQL数据库设计篇 概述 做服务端开发离不开数据库设计,虽然说服务端技术一直在革新,但是MySQL一直都是我们首选使用的关系型数据库。服务端开发一直以来都是采用数据驱动研发的思想,可见数据库设计是非常重要的,数据库设计的好坏…

python--初学函数

函数(function): 什么是函数? 具有名称的,是为了解决某一问题,功能代码的集合,叫做函数 python中函数如何定义:def>define function定义函数 def function_name([args临时变量…

docker推拉时的数据交换详解

前言 docker用了这么久了, 有没有想过, 在执行docker push 和 docker pull命令的时候, 数据是如何传递的呢? 换句话说, 如果要实现一个镜像仓库, 针对推拉的服务, 如何实现接口呢? 根据OCI 分发规范文档 的描述, 已经对整个推拉过程中要调用的接口有描述了. 但是, 纸上学来…

蓝桥集训之矩形牛棚

蓝桥集训之矩形牛棚 核心思想&#xff1a;单调队列 模板&#xff1a;Acwing.131.直方图矩形面积首先遍历所有下界 然后确定以该下界为底的直方图 求最大矩形 #include <iostream>#include <cstring>#include <algorithm>using namespace std;const int N 30…

前端基础篇-前端工程化 Vue 项目开发流程(环境准备、Element 组件库、Vue 路由、项目打包部署)

&#x1f525;博客主页&#xff1a; 【小扳_-CSDN博客】 ❤感谢大家点赞&#x1f44d;收藏⭐评论✍ 文章目录 1.0 环境准备 1.1 安装 NodeJs 1.2 验证 NodeJs 环境变量 1.3 配置 npm 的全局安装路径 1.4 切换 npm 的淘宝镜像( npm 使用国内淘宝镜像的方法(最新) ) 1.5 查看镜像…

win10-误删winsock恢复方法

文件链接放在最前面 链接&#xff1a;https://pan.baidu.com/s/1i9X0HJJOfo63fbtOETc1Xw?pwdlfqx 提取码&#xff1a;lfqx 误删后应该还是可以正常连接网络的&#xff0c;但是重启过后直接以太网和wifi都是无法使用的。下图是我后面网络正常补充的图片 误删后是只有飞行模式…

C语言操作符和数据类型的存储详解

CSDN成就一亿技术人 目录​​​​​​​ 一.操作符 一.算数操作符&#xff1a; 二.位移操作符&#xff1a; 三.位操作符&#xff1a; 四.赋值操作符&#xff1a; 五.单目操作符&#xff1a; 六.关系操作符&#xff1a; 七.逻辑操作符&#xff1a; 八.条件操作符&…