BP神经网络原理及MATLAB实现

人工神经网络概述:

人工神经元模型:

神经网络的分类:

按照连接方式,可以分为:前向神经网络 vs. 反馈(递归)神经网络;

按照学习方式,可以分为:有导师学习神经网络 vs. 无导师学习神经网络;

按照实现功能,可以分为:拟合(回归)神经网络 vs. 分类神经网络。

数据归一化:将数据映射到[0, 1]或[-1, 1]区间或其他的区间。

数据归一化的原因:

1.输入数据的单位不一样,有些数据的范围可能特别大,导致的结果是神经网络收敛慢、训练时间长。
2.数据范围大的输入在模式分类中的作用可能会偏大,而数据范围小的输入作用就可能会偏小。
3.由于神经网络输出层的激活函数的值域是有限制的,因此需要将网络训练的目标数据映射到激活函数的值域。例如神经网络的输出层若采用S形激活
函数,由于S形函数的值域限制在(0,1),也就是说神经网络的输出只能限制在(0,1),所以训练数据的输出就要归一化到[0,1]区间。
4.S形激活函数在(0,1)区间以外区域很平缓,区分度太小。例如S形函数f(X)在参数a=1时,f(100)与f(5)只相差0.0067。
归一化算法:
1.y = ( x - min )/( max - min );
2.y = 2 * ( x - min ) / ( max - min ) - 1。

部分函数:

参数对BP神经网络性能的影响:

隐含层神经元节点个数

激活函数类型的选择

学习率

初始权值与阈值

交叉验证

训练集

测试集

验证集

留一法

MATLAB实现程序:

 1 %% I. 清空环境变量
 2 clear all
 3 clc
 4 
 5 %% II. 训练集/测试集产生
 6 %%
 7 % 1. 导入数据
 8 load spectra_data.mat
 9 
10 %%
11 % 2. 随机产生训练集和测试集
12 temp = randperm(size(NIR,1));
13 % 训练集——50个样本
14 P_train = NIR(temp(1:50),:)';
15 T_train = octane(temp(1:50),:)';
16 % 测试集——10个样本
17 P_test = NIR(temp(51:end),:)';
18 T_test = octane(temp(51:end),:)';
19 N = size(P_test,2);
20 
21 %% III. 数据归一化
22 [p_train, ps_input] = mapminmax(P_train,0,1);
23 p_test = mapminmax('apply',P_test,ps_input);
24 
25 [t_train, ps_output] = mapminmax(T_train,0,1);
26 
27 %% IV. BP神经网络创建、训练及仿真测试
28 %%
29 % 1. 创建网络
30 net = newff(p_train,t_train,9);
31 
32 %%
33 % 2. 设置训练参数
34 net.trainParam.epochs = 1000;
35 net.trainParam.goal = 1e-3;
36 net.trainParam.lr = 0.01;
37 
38 %%
39 % 3. 训练网络
40 net = train(net,p_train,t_train);
41 
42 %%
43 % 4. 仿真测试
44 t_sim = sim(net,p_test);
45 
46 %%
47 % 5. 数据反归一化
48 T_sim = mapminmax('reverse',t_sim,ps_output);
49 
50 %% V. 性能评价
51 %%
52 % 1. 相对误差error
53 error = abs(T_sim - T_test)./T_test;
54 
55 %%
56 % 2. 决定系数R^2
57 R2 = (N * sum(T_sim .* T_test) - sum(T_sim) * sum(T_test))^2 / ((N * sum((T_sim).^2) - (sum(T_sim))^2) * (N * sum((T_test).^2) - (sum(T_test))^2)); 
58 
59 %%
60 % 3. 结果对比
61 result = [T_test' T_sim' error']
62 
63 %% VI. 绘图
64 figure
65 plot(1:N,T_test,'b:*',1:N,T_sim,'r-o')
66 legend('真实值','预测值')
67 xlabel('预测样本')
68 ylabel('辛烷值')
69 string = {'测试集辛烷值含量预测结果对比';['R^2=' num2str(R2)]};
70 title(string)

     

运行效果截图:

附测试代码及数据:GitHub - wydxry/Learn-about-Back-Propagation-Neural-Network: Test data and MATLAB code about Back Propagation Neural Network

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
BP神经网络是一种常用的人工神经网络模型,用于进行数据预测和模式识别。在MATLAB中,可以使用不同的优化算法实现BP神经网络的训练和预测。 引用提供了BP神经网络的结构参数和训练界面的参数解读,以及实现BP网络预测的步骤。通过编写MATLAB代码,可以实现BP神经网络的建模和预测。引用中列举了多种优化算法来优化BP神经网络的回归预测,包括遗传算法、粒子群算法、灰狼优化算法、布谷鸟搜索算法等等。这些算法可以根据具体的问题选择合适的优化方法。 引用提供了BP神经网络的流程图,其中包括了标准BP神经网络和批训练BP神经网络的不同误差调整方式。标准BP神经网络是每输入一个样本就计算相应误差进行调整,而批训练BP神经网络是计算所有样本的总误差进行调整。 因此,根据引用的内容,可以使用MATLAB编写BP神经网络的代码,并根据具体问题选择合适的优化算法来提高神经网络的性能。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [BP神经网络预测matlab代码讲解与实现步骤](https://blog.csdn.net/qq_57971471/article/details/121766454)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [Bp神经网络详解—matlab实现Bp神经网络](https://blog.csdn.net/m0_52792591/article/details/124435325)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值