- 在线时间
- 10 小时
- 最后登录
- 2012-9-21
- 注册时间
- 2012-5-30
- 听众数
- 5
- 收听数
- 0
- 能力
- 0 分
- 体力
- 248 点
- 威望
- 0 点
- 阅读权限
- 30
- 积分
- 112
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 78
- 主题
- 2
- 精华
- 0
- 分享
- 0
- 好友
- 7
升级   6% TA的每日心情 | 难过 2012-9-21 11:07 |
---|
签到天数: 19 天 [LV.4]偶尔看看III
- 自我介绍
- good
 |
程序如下,求教:这里的B10=cat(2,B1,B1);是什么作用,矩阵的维数怎么变成了S1*Q了?我查了一下,B10=cat(2,B1,B1);的话,维数应该是S1*R*2了啊?求教高手指点' }: o* d" G2 w8 i1 G: }
5 u! O/ Z5 {* Z/ ~# d# o$ x
clear
" @1 W0 c+ } l: \- y7 p Lclc
7 p; D: k! i, N0 H+ N* i%eg1_2 三层神经网络输出. e) ]/ H+ c; W# d- Z
P=[0.1,0.5;0.3,-0.2];%已知输入矢量数据
4 I$ P& l6 _6 [' _5 u[R,Q]=size(P); %已知各层节点数8 @8 v* N& g' R6 l+ W; r4 x; k3 O
S1=2;S2=3;S3=5; %求出输入矢量的行和列8 A4 S7 v$ u6 [$ ^9 J; D4 r! O
[W1,B1]=rands(S1,R); %给第一隐含层权值赋(-1,1)之间的随机值
# h. E' T; H& R5 k. H[W2,B2]=rands(S2,S1);%给第二隐含层权值赋(-1,1)之间的随机数
* v0 V E6 J5 G. k- O7 p[W3,B3]=rands(S3,S2);%给输出层权值赋(-1,1)之间的随机值
4 S. Q% P: k6 a+ m1 {0 R0 l6 ]9 pB10=cat(2,B1,B1); %通过B10=[B1,B1]将S1*1的B1矩阵合成为一个S1*Q的矩阵以便进行下面的加法运算& n, d5 Q# f$ w6 J; m
A1=hardlims(W1*P+B10);%计算第一层输出表达式
2 x1 I7 s' T' [4 J9 D; a, zB20=cat(2,B2,B2); %用两个S2*1的B2矩阵组成一个S2*Q矩阵
/ V; y! W1 G4 L! U5 j A$ j' QA2=logsig(W2*A1+B20); %计算第二层输出& m' \& ^8 c( r" B+ z5 L( E
B30=cat(2,B3,B3); %用两个S3*1的B3矩阵组成一个S3*Q矩阵, ]# ]6 b. M6 j: k/ x
A3=purelin(W3*A2+B30) %计算第三层输出
) N" Z2 i5 d5 B2 c2 L& D |
zan
|