zoukankan      html  css  js  c++  java
  • 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)

    运行效果截图:

    附测试代码及数据:https://github.com/shixinzei/Learn-about-Back-Propagation-Neural-Network

  • 相关阅读:
    jQury+Ajax与C#后台交换数据
    loadrunner 测试问题汇总
    Loadrunner脚本学习总结
    sar命令详解
    用sar进行CPU利用率的分析
    centos7-sar工具的安装过程及其简单应用
    shell if [ -d filename]
    shell脚本自带变量的含义
    Sublime Text2使用规则
    selenium grid结构图
  • 原文地址:https://www.cnblogs.com/shixinzei/p/10765399.html
Copyright © 2011-2022 走看看