QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4150|回复: 3
打印 上一主题 下一主题

[已经解决] BP神经网络预测遇到一个疑问,麻烦过来看看

[复制链接]
字体大小: 正常 放大

23

主题

8

听众

372

积分

升级  24%

  • TA的每日心情
    开心
    2014-10-4 18:19
  • 签到天数: 102 天

    [LV.6]常住居民II

    自我介绍
    本人是在校学生,即将参加有史以来的第一场国赛,希望能在这里获得帮助。
    跳转到指定楼层
    1#
    发表于 2013-9-8 17:22 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    本帖最后由 数学不烦 于 2013-9-9 21:56 编辑
    * k" A' z. x  n4 Y" Q, d
    , G* ~# P4 y+ }, D; K! I各位朋友,有一个问题请教你们。   我用BP神经网络做预测的时候(下面是我的代码)遇到一个问题。  首先我尝试在代码里面不把数据归一化,这样的出来的结果很差(R=0.46).但我把数据作归一化 与 反归一化 之后 确实R提高了很多(R=0.99),这时问题就来了,请看最下面的测试结果代码,那里只有输入(没有输出,因为是预测),premnmx 归一化要有输出的变量T,但我只有输入数据,没有输出数据,因此反归一的结果(最后的预测结果)也无法做到。那么我的预测就不是做不了吗?  很纠结,查了很多资料了,还是不知道怎么解决。
    & U* J6 E2 q* c- c1 N国赛准备到了,希望热心的朋友懂的不吝赐教,我把问题写得很认真,希望各位能帮我解决这个问题,谢谢了。
    % [* J: x4 M3 L. J8 `; a3 q; U1 k& r/ B, a9 T5 G2 V% r- s- x( `
    clear
    . O. K8 o* i- [7 L" nclc1 o% z; a# Y, y' J) \5 v  P& O
    %输入数据--以一列作为一个输入数据$ d  w+ t* z5 T' R0 y& u1 y
    x1=[227.5 286.9 236.3 300.6 243.0];
    ' f  c7 Y7 A" M" \2 T' Hx2=[286.9 236.3 300.6 243.0 354.1];
    7 e5 I2 p7 |( v3 [/ A# J3 @+ nx3=[236.3 300.6 243.0 354.1 294.1];
    , L0 }, r& D: D+ j% L( px4=[300.6 243.0 354.1 294.1 361.4];7 V% ?# F$ x! S! r4 k
    x5=[243.0 354.1 294.1 361.4 333.7];2 D% S8 l7 `! W) ~6 M. W
    x6=[354.1 294.1 361.4 333.7 426.4];: }, z% D, c1 X" l) M
    x7=[294.1 361.4 333.7 426.4 434.4];/ U+ I, M3 T0 y( l& L
    x8=[361.4 333.7 426.4 434.4 449.9];
      c# \: ?0 _* S: F+ J$ nx9=[333.7 426.4 434.4 449.9 431.9];. K) E/ c" u$ R: @) @" D0 [
    : _  {# p, i' I
    P=[x1;x2;x3;x4;x5;x6;x7;x8;x9]';( z) j) {, O7 i8 k4 J3 \
    %输出数据--以一列作为一个输出数据
    6 Z4 A  w' f- W& ^1 Xy1=[354.1 294.1 361.4 333.7 426.4];: L/ P% j& M2 S$ |* H. ?" k* h, [$ l
    y2=[294.1 361.4 333.7 426.4 434.4];
    % n) ], f$ D) z6 ry3=[361.4 333.7 426.4 434.4 449.9];! N1 V$ e+ Y/ D8 m
    y4=[333.7 426.4 434.4 449.9 431.9];
    2 Y$ t& p( c0 f3 ny5=[426.4 434.4 449.9 431.9 454.0];3 I8 J1 }6 c; ~3 Q; G
    y6=[434.4 449.9 431.9 454.0 655.6];
    ' J5 y( M/ A: ?# }; n  A) yy7=[449.9 431.9 454.0 655.6 907.0];/ _4 N( v# G& ^
    y8=[431.9 454.0 655.6 907.0 1112.5];
    1 h8 n& V" |2 w3 Iy9=[454.0 655.6 907.0 1112.5 1401.1];) t" o+ |- o, t) F2 r
    / k! z: ?5 c) j% K5 `# _
    T=[y1;y2;y3;y4;y5;y6;y7;y8;y9]';
    0 D( e! G* x1 P2 `. t) |, r% }/ ?$ a8 h7 _" b" @
    %归一化, K( X- e- \% F8 q( S2 e
    % [P,minp,maxp,T,mint,maxt] = premnmx(P,T);
      u' H$ {2 q2 y! G* v%建立网络6 W- N, @, ~! N9 W- f7 w( B
    %其中[10,3]代表有一个隐含层,里面有10个神经元;“3”代表有三个输出数据4 x' y, {( a* f/ G2 h
    %{'tansig','purelin'}与[10,3]对应,意思为隐含层 与 输出层
    . I2 ]/ J. c# f. X6 T' L%'traingdm' 表示调整权重,缩小误差的数学函数% F" t) o" o4 A  n" I- ]
    %↓创建一个新的前向神经网络  # _6 [. O* P; n
    net = newff(minmax(P),[6,5],{'tansig','purelin'},'traingdm')
    8 T' D7 ^9 ^5 P# t+ t; Q" x; c2 }
    %  当前输入层权值和阈值
    5 V* J* I% k( ~inputWeights = net.IW(1,1)
    9 ?6 c% u- o* E& Winputbias = net.b(1)
    * p& m7 ]4 @$ J' M* Z& y
    ' G* g: V4 |  C! p" H+ h%  当前网络层权值和阈值 7 g2 {. G2 c/ z+ |" E, p
    layerWeights = net.LW(2,1)4 o# ?$ \% u7 A7 y5 ~# ~
    layerbias = net.b(2)
    - _7 \! r- s$ o1 m$ j2 {8 m
    1 _% N  X/ ^! d6 Y0 h6 }%  设置训练参数& Y0 M4 k- D$ E# n' p" Z- q
    net.trainParam.show = 50;
    ) V+ r; z0 ]  E, F8 l% y! {+ Tnet.trainParam.lr = 0.05;" P$ o% P+ z: w; x
    net.trainParam.mc = 0.9;- ^# D3 l* f2 Z6 ~9 Y! \
    net.trainParam.epochs = 10000;  %每计算10000次出一次结果9 N( J% |" E) Y
    net.trainParam.goal = 1e-6;     %期望达到的误差(认为是合适的误差)
    7 L1 D' ^) h# |  \; p% W" M; Y5 I5 c
    %  调用 TRAINGDM 算法训练 BP 网络
    + R/ U8 w9 V1 a6 C7 S[net,tr] = train(net,P,T);      + R: @6 v. _8 I" o

    ' n1 Z' ]8 |/ H%  对 BP 网络进行仿真5 y! `4 P# Y- w$ q" O
    A = sim(net,P);                 %A为输出结果
    & B3 ?0 C# n) g) ]2 @- P% P$ `1 U+ x
    %反归一化
      c6 e# l! r" D/ N( O%  A = postmnmx(A,mint,maxt);
    - c/ e( P* f6 ^4 w
    2 W0 }; D1 o* s7 L/ W%  计算仿真误差  7 a3 m+ N% }; p% i2 }& }* v8 U
    E = T-A;                        %原来的输出 - 训练输出 = 误差
    ( w+ V  S" N7 R% d0 x: UMSE = mse(E)                    %输出误差5 U6 L" A6 u! h. l' o$ }

    * O4 F2 E, P6 |1 H# r: ?%下面是输入数据,测试结果, V' @! v* P, A: h% r6 ~
    x=[454.0 655.6 907.0 1112.5 1401.1]';, T+ d3 }7 a5 {1 L) O6 H3 n9 e
    Y = sim(net,x)
    $ ]6 t; w  e4 Q7 j; {
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    magic2728 实名认证    中国数模人才认证   

    61

    主题

    478

    听众

    4851

    积分

    升级  95.03%

  • TA的每日心情
    慵懒
    2014-9-29 19:37
  • 签到天数: 409 天

    [LV.9]以坛为家II

    群组数学中国 2015美赛护航

    群组数模专题强化培训

    群组建模思维养成培训

    群组2015美赛护航(强化)

    群组2013年数学建模国赛备

    回复

    使用道具 举报

    kaito1412        

    63

    主题

    8

    听众

    3098

    积分

    升级  36.6%

  • TA的每日心情
    开心
    2020-7-21 15:56
  • 签到天数: 829 天

    [LV.10]以坛为家III

    回复

    使用道具 举报

    19

    主题

    11

    听众

    272

    积分

    升级  86%

  • TA的每日心情
    郁闷
    2014-10-23 09:29
  • 签到天数: 59 天

    [LV.5]常住居民I

    不知道你最后是怎么解决的,感觉你最后预测的时候没有把输入数据进行归一化,即要对x进行归一化,再对y进行反归一化,这是我的看法,不知道对不对
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-6-3 07:57 , Processed in 0.429083 second(s), 71 queries .

    回顶部