找回密码
 注册
关于网站域名变更的通知
查看: 369|回复: 1
打印 上一主题 下一主题

BP神经网络MATLAB实现

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2020-10-27 11:04 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
: Q- S/ a6 i/ ]1 [  [
文章目录
9 F1 J  R6 r$ }& y) r
  • BP神经网络$ V! {6 i& C$ e- L
  • MATLAB代码
  • 效果
    8 p1 r1 p9 l0 ~
" ^4 n+ e. T2 O
BP神经网络5 k* M8 ^1 |9 w, |
BP(back propagation)神经网络是1986年由Rumelhart和McClelland为首的科学家提出的概念,是一种按照误差逆向传播算法训练的多层前馈神经网络,是目前应用最广泛的神经网络。0 l7 \6 x" T- d. z2 u

3 c" W, d  o! x) l3 wBP神经网络的计算过程由正向计算过程和反向计算过程组成。正向传播过程,输入模式从输入层经隐单元层逐层处理,并转向输出层,每~层神经元的状态只影响下一层神经元的状态。如果在输出层不能得到期望的输出,则转入反向传播,将误差信号沿原来的连接通路返回,通过修改各神经元的权值,使得误差信号最小。% K" y' I/ g5 X5 [. [; j9 \
* H' ?  Y) U0 Q" A3 Z& s% O1 a+ `
MATLAB代码
  Q& K/ L1 |( k( ?: A  g
: k. }  c  Y& s; `0 U/ l* Z3 m. H
  • clc
  • clear all
  • %读取训练数据
  • [f1,f2,f3,f4,class] = textread('trainData.txt' , '%f%f%f%f%f',150);
  • %特征值归一化
  • [input,minI,maxI] = premnmx( [f1 , f2 , f3 , f4 ]')  ;
  • %构造输出矩阵
  • s = length( class) ;
  • output = zeros( s , 3  ) ;
  • for i = 1 : s
  •    output( i , class( i )  ) = 1 ;
  • end
  • %创建神经网络
  • net = newff( minmax(input) , [10 3] , { 'logsig' 'purelin' } , 'traingdx' ) ;
  • %设置训练参数
  • net.trainparam.show = 50 ;
  • net.trainparam.epochs = 500 ;
  • net.trainparam.goal = 0.01 ;
  • net.trainParam.lr = 0.01 ;
  • %开始训练
  • net = train( net, input , output' ) ;
  • %读取测试数据
  • [t1 t2 t3 t4 c] = textread('testData.txt' , '%f%f%f%f%f',150);
  • %测试数据归一化
  • testInput = tramnmx ( [t1,t2,t3,t4]' , minI, maxI ) ;
  • %仿真
  • Y = sim( net , testInput )
  • %统计识别正确率
  • [s1 , s2] = size( Y ) ;
  • hitNum = 0 ;
  • for i = 1 : s2
  •     [m , Index] = max( Y( : ,  i ) ) ;
  •     if( Index  == c(i)   )
  •         hitNum = hitNum + 1 ;
  •     end
  • end
  • sprintf('识别率是 %3.3f%%',100 * hitNum / s2 )

  • 0 Q- }$ I" J3 d. U$ Z5 H) T/ X3 S
              
8 u' u9 K, S  n# @" U/ H效果- `4 F9 `+ h6 T1 [" {* U  F, H
识别率是 97.333%' b2 k+ W: S' R: ~' D

2 H2 }. ~/ `6 R& H3 Y0 m7 x8 F( F: ^8 S. [/ I3 Z% R$ Q2 \: n

该用户从未签到

2#
发表于 2020-10-27 13:19 | 只看该作者
BP神经网络MATLAB实现
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-6-21 19:57 , Processed in 0.078125 second(s), 26 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

快速回复 返回顶部 返回列表