在线时间 1084 小时 最后登录 2015-9-10 注册时间 2014-4-18 听众数 162 收听数 1 能力 10 分 体力 43980 点 威望 6 点 阅读权限 255 积分 15251 相册 0 日志 0 记录 1 帖子 3471 主题 2620 精华 1 分享 0 好友 513
升级 0%
TA的每日心情 开心 2015-3-12 15:35
签到天数: 207 天
[LV.7]常住居民III
群组 : 第六届国赛赛前冲刺培
群组 : 国赛讨论
群组 : 2014美赛讨论
群组 : 2014研究生数学建模竞
群组 : 数学中国试看培训视频
第一部分 单层感知器原理 0 W" A0 o% f/ S
感知器是美国学者在1957年首次提出的作为有导师学习的神经网络模型,单层感知器是指包含一个突触权值可调的神经元的感知器模型,它的学习算法是Rosenblatt在1958年提出的,感知器网络是神经网络用来进行模式识别的最简单模型,属于前向神经网络类型,但是仅由单个神经元组成的单层感知器只能用来实现线性可分的两类模式的识别。 5 |( y2 C' e2 N }6 O" O
感知器网络的模型如下图 所示:
' g1 R! I2 B5 U, i' | 3 H9 ^0 c: ~& ^1 S5 q9 |* Z
感知器网络的学习算法:
" l3 O$ k: x, Z+ X
单层感知器网络的学习算法是基于迭代的思想,通常是采用误差校正规则的学习算法,算法的学习过程为:
2 y7 k+ y; @, H$ p 第二部分 MATLAB相关函数 newp() 生成一个感知机 init() 初始化一个神经网络
3 ~1 h0 G$ [* i" [% G mae() 平均绝对误差性能函数
( M4 t* i- h/ t8 C2 p# L1 U! { hardlim() 硬限幅传输函数
0 v+ B! r9 v8 p7 O hardlims() 对称硬限幅传输函数
$ x+ N4 A W" ^ plotpv() 在坐标图上绘出样本点 " v% h% j# I: D D9 I
plotpc() 在已绘制的图上加分类线 " E T' p: Q1 N' Q% H: m" [; K
train() 神经网络训练函数 , G& |& A5 p8 v+ g8 C
learnp() 感知机的学习函数
4 o0 V6 a5 i/ L/ y7 z4 X! T) E 1earnpn() 标准化感知机的学习函数 3 N$ y8 O( s) f* D9 Z _
adapt() 神经网络自适应调整函数 + _; F6 q7 O6 K% H
sim() 神经网络仿真函数
; |# m, | f# Z. j) w1 r# k) E# @ netsum() 输入求和函数 . i" c* u. O, v2 p4 H6 }1 q
3 v( K# }' ?( b) g. w1 I$ i 第三部分 相关代码" P6 z, W/ T! W" J% i* T
%创建一个有两个输入、样本数据的取值范围都在[-1,1]之间,并且网络只有一个神经元的感
: X( a4 ` o/ ^( | %知器神经网络 5 C5 W8 J! X# m
net=newp([-1 1;-1 1],1); 9 l T. @" ~% [1 s6 U3 T- |
%设置网络的最大训练次数为20次,即训练20次后结束训练
' M3 Z) k1 u+ {. R! Z net.trainParam.epochs = 20; , R M$ J% A$ ~ K9 a
%使用训练函数对创建的网络进行训练 2 r* O8 I3 k9 D. L' }
net=train(net,P,T); - y$ N7 D% h, P! k; F' J( Z s
%对训练后的网络进行仿真,即根据训练后的网络和样本数据给出输出 6 t( _. Y$ O" y6 s5 {
Y=sim(net,P)
3 n& ^3 U. b1 Y, `) d2 e* |" |2 ? %计算网络的平均绝对误差,表示网络错误分类 ; B1 O+ f$ T$ h1 J/ j5 U
E1=mae(Y-T) 0 f# P& S" j' y+ e- \8 \
%给定测试数据,检测训练好的神经网络的性能 . @) _, U$ e+ J" R
Q=[0.6 0.9 -0.1; -0.1 -0.5 0.5]; & e% G( g* v# R
%使用测试数据,对网络进行仿真,仿真输出即为分类的结果
6 M) z" U' ]0 X5 Z3 \ Y1=sim(net,Q)
# C8 J- C* p4 U %创建一个新的绘图窗口
* h" u' G/ a- {5 `
# \6 z# G7 _0 S5 l
- Q! I: L% a# f% F2 R6 p
zan