matlab BP神经网络回归预测(套用任何数据不改代码,最后一列是标签)

部分代码: 

%% BP神经网络
% 清空环境变量 关闭打开过的图表
clear all;clc;close all  
%% 导入数据
data=xlsread('data1.xlsx');
%% 设置训练集数量
num_row=size(data,1)        %数据集行数
n_trains=floor(num_row*0.8) %按比例求训练集数目
% n_trains=150              %也可直接指定
%% 训练集输入输出
input_train=data(1:n_trains,1:end-1);%一至倒数第一列做特征
output_train=data(1:n_trains,end);   %最后一列做标签%% 测试样本输入值归一化
inputn_test=mapminmax('apply',input_testT,inputps);% inputps准则对输入值进行归一化
%测试样本输出值不用归一化
%% 构建BP神经网络(归一化后的输入,输出 构建)
net=newff(inputn,outputn,10);%单隐层,10个神经元
% net=newff(inputn,outputn,[8,15]);%多隐层,8个神经元
%% 网络参数配置( 训练次数,学习速率,训练目标最小误差等)
net.trainParam.epochs=3000;              % 训练次数,这里设置为1000次
net.trainParam.lr=0.02;                   % 学习速率,这里设置为0.01
net.trainParam.goal=0.000001;            % 训练目标最小误差,这里设置为0.00001
%% BP神经网络训练
net=train(net,inputn,outputn);%开始训练,其中inputn,outputn分别为输入,输出样本
%% BP神经网络预测
test_simu=sim(net,inputn_test); %用训练好的模型进行仿真
%% 预测结果反归一化    
test_simu=mapminmax('reverse',test_simu,outputps); %把仿真得到的数据还原为原始的数量级
%% 转置回来【因归一化之前转置过】
test_simu=test_simu';
%% 评估rmse与mae
rmse=sqrt(mean((test_simu-output_test).^2));
disp(['均方根误差(RMSE):',num2str(rmse)])
mae=mean(abs(test_simu-output_test));
disp(['平均绝对误差(MAE):',num2str(mae)])
%% 绘图真实值与预测值比较
figure(1)  
plot(output_test,'bo-')
hold on
plot(test_simu,'r*-')
legend('实际值','预测值')
title("预测对比图")
xlabel('样本')
ylabel('值')

 免费代码

更多:请访问🍞正在装饰个人主页...

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

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

相关文章

JDK和IntelliJ IDEA下载和安装及环境配置教程

一、JDK下载(点击下方官网链接) Java Downloads | Oracle 选择对应自己电脑系统往下拉找到自己想要下载的JDK版本进行下载,我下的是jdk 11,JDK有安装版和解压版,我就直接下安装版的了。 .exe和.zip的区别&#xff1a…

通过MobaXterm工具可视化服务器桌面

一、MobaXterm工具 MobaXterm是一款功能强大的远程连接工具,可以连接到各种类型的服务器,包括Linux、Windows和MacOS。支持多种协议,包括SSH、RDP、VNC和Telnet MobaXterm可以通过X11转发功能可视化服务器桌面。 二、MobaXterm工具可视化服务…

011——人体感应模块驱动开发(SR501)

目录 一、 模块简介 二、 工作原理 三、 软件及验证 一、 模块简介 人体都有恒定的体温,一般在 37 度,所以会发出特定波长 10uM 左右的红外线,被动式红外探头就是靠探测人体发射的 10uM 左右的红外线而进行工作的。 人体发射的 10…

高等代数复习:矩阵秩的基本公式

文章目录 矩阵秩的基本公式初等变换方法线性方程组方法 本篇文章适合个人复习翻阅,不建议新手入门使用 矩阵秩的基本公式 均记矩阵 A A A 的秩为 r ( A ) r(A) r(A) 初等变换方法 结论1: r ( k A ) r ( A ) , ∀ k ≠ 0 r(kA)r(A),\forall k\neq …

架构师之路--Docker的技术学习路径

Docker 的技术学习路径 一、引言 Docker 是一个开源的应用容器引擎,它可以让开发者将应用程序及其依赖包打包成一个可移植的容器,然后在任何支持 Docker 的操作系统上运行。Docker 具有轻量级、快速部署、可移植性强等优点,因此在现代软件开…

Hides for Mac:应用程序隐藏工具

Hides for Mac是一款功能强大的应用程序隐藏工具,专为Mac用户设计。它能够帮助用户快速隐藏当前正在运行的应用程序窗口,保护用户的隐私和工作内容,避免不必要的干扰。 软件下载:Hides for Mac下载 Hides for Mac的使用非常简单直…

python处理字典之表格-城市排行榜

# 中国城市排行榜 import xlrd bookxlrd.open_workbook(city_data.xls) sheetbook.sheet_by_index(0) main_data_list[] for row in range(3,sheet.nrows):temp_dict{}# print(sheet.row_values(row))temp_dict["城市"]sheet.row_values(row)[0]temp_dict["2019…

电脑换屏总结——关于我把电脑砸了这件事!

大家好,我是工程师看海,很高兴和各位一起分享我的原创文章,喜欢和支持我的工程师,一定记得给我点赞、收藏、分享哟。 加微信[chunhou0820]与作者进群沟通交流。 【淘宝】https://m.tb.cn/h.5PAjLi7?tkvmMLW43KO7q CZ3457 「运放秘…

vite+vue3使用模块化批量发布Mockjs接口

在Vue3项目中使用Mock.js可以模拟后端接口数据,方便前端开发和调试。下面是使用vitevue3使用模块化批量发布Mockjs接口的步骤: 1. 安装Mock.js 在Vue3项目的根目录下,使用以下命令安装Mock.js: npm install mockjs --save-dev …

项目亮点—动态线程池管理工具

问题 你是否在项目中使用线程池遇到过以下问题? 1.创建线程池核心参数不好评估,随着业务流量的波动,极有可能出现生产故障。 2.不支持优雅关闭,当项目关闭时,大量正在运行的线程池任务被丢弃。 3.不支持运行时监控…

Linux安装wine

#教程 一直以来,我运行双系统,有两个软件必须在window下运行,一个是wind金融终端,一个是通达信金融终端,现已解决这两个软件在linux(debian系)环境下运行问题,记录如下:…

WebGIS开发

1.准备工作 高德开发API注册账号&#xff0c;创建项目拿到key和密钥 高德key 2.通过JS API引入高德API <html><head><meta charset"utf-8" /><meta http-equiv"X-UA-Compatible" content"IEedge" /><metaname&quo…

【3D-GS】Gaussian Splatting SLAM——基于3D Gaussian Splatting的全网最详细的解析

【3D-GS】Gaussian Splatting SLAM——基于3D Gaussian Splatting的定SLAM 3D-GS 与 Nerf 和 Gaussian Splatting1. 开山之作 Nerf2. 扛鼎之作 3D Gaussian Splatting2.1 什么是3D高斯?高斯由1D推广到3D的数学推导2.2 什么是光栅化?2.3 什么是Splatting?2.4 什么是交叉优化?…

AWS EC2 学习之: 使用 PuTTY 从 Windows 连接到 Linux 实例

启动您的实例之后&#xff0c;您可以连接到该实例&#xff0c;然后像使用您面前的计算机一样来使用它。 注意 启动实例后&#xff0c;需要几分钟准备好实例&#xff0c;以便您能连接到实例。检查您的实例是否通过了状态检查。您可以在 Instances 页上的 Status Checks 列中查…

什么是防火墙,部署防火墙有什么好处?

与我们的房屋没有围墙或界限墙一样&#xff0c;没有防护措施的计算机和网络将容易受到黑客的入侵&#xff0c;这将使我们的网络处于巨大的风险之中。因此&#xff0c;就像围墙保护我们的房屋一样&#xff0c;虚拟墙也可以保护和安全我们的设备&#xff0c;使入侵者无法轻易进入…

如何处理网络编程中的并发连接?

如何处理网络编程中的并发连接&#xff1f; 在网络编程中&#xff0c;处理并发连接是一个至关重要的问题。随着网络应用的普及和用户量的增长&#xff0c;服务器需要同时处理来自多个客户端的请求&#xff0c;因此必须有效地管理并发连接。下面将详细讨论如何处理网络编程中的…

SAP Fiori开发中的JavaScript基础知识9 - 代码注释,严格模式,JSON

1 背景 本文将介绍JavaScript编程中的三个小知识点&#xff1a;也即代码注释&#xff0c;严格模式&#xff0c;JSON文件。 2 代码注释 JavaScript的代码注释方式如下&#xff1a; // Single line comment/* Multi line comment */3 严格模式 JavaScript的"strict mod…

JavaScript笔记 07

目录 01 基本数据类型和引用数据类型之间的区别 02内置对象之Array 01 基本数据类型和引用数据类型之间的区别 js的数据内存结构是参照java诞生的 内存分为栈内存和堆内存 栈内存: 空间很小 存储基本数据类型 堆内存: 空间很大 引用数据类型声明在栈内存 内容在堆内存 使用地…

0101支付安全-支付模块-项目实战

文章目录 一、信息安全的基础-机密性1 相关概念2 对称加密和非对称加密 二、身份认证三 摘要算法四、数字签名五、数字证书结语 在支付过程中&#xff0c;设计多方的敏感信息&#xff0c;那么安全尤为重要。下面先简单介绍下&#xff0c;相关概念。 一、信息安全的基础-机密性 …

解决GNU Radio+USRP实现OFDM收发在接收端QPSK星座图映射无“抖动”问题

文章目录 前言一、遇到的问题二、解决方案三、重新编译安装四、验证五、资源自取 前言 本文记录在 GNU RadioUSRP 实现 OFDM 收发时&#xff0c;在接收端 QPSK 星座图映射无“抖动”问题的解决方法&#xff0c; 一、遇到的问题 我遇到的问题是&#xff0c;现在搭建的 OFDM 模…