数学建模社区-数学中国
标题:
BP神经网络预测遇到一个疑问,麻烦过来看看
[打印本页]
作者:
数学不烦
时间:
2013-9-8 17:22
标题:
BP神经网络预测遇到一个疑问,麻烦过来看看
本帖最后由 数学不烦 于 2013-9-9 21:56 编辑
% b2 E# x# ?+ W& _, z: a7 _& z' c6 O
- ~3 K+ R) o5 y6 e9 W" t& m
各位朋友,有一个问题请教你们。 我用BP神经网络做预测的时候(下面是我的代码)遇到一个问题。 首先我尝试在代码里面不把数据归一化,这样的出来的结果很差(R=0.46).但我把数据作归一化 与 反归一化 之后 确实R提高了很多(R=0.99),这时问题就来了,请看最下面的测试结果代码,那里只有输入(没有输出,因为是预测),premnmx 归一化要有输出的变量T,但我只有输入数据,没有输出数据,因此反归一的结果(最后的预测结果)也无法做到。那么我的预测就不是做不了吗? 很纠结,查了很多资料了,还是不知道怎么解决。
& {( s0 N0 ?& Z1 @. _; G% n1 o
国赛准备到了,希望热心的朋友懂的不吝赐教,我把问题写得很认真,希望各位能帮我解决这个问题,谢谢了。
- `0 n5 b& i; z6 i: a
# H6 }3 c3 q ^$ ]- }: t
clear
" w1 Q* ?: H- h$ T
clc
. y. w& b6 w) t, ` Y, y
%输入数据--以一列作为一个输入数据
! a5 q: d# v% Y
x1=[227.5 286.9 236.3 300.6 243.0];
" p6 X5 w9 o6 v; v& X- V
x2=[286.9 236.3 300.6 243.0 354.1];
" h1 q4 ]4 f0 r" g% s- W
x3=[236.3 300.6 243.0 354.1 294.1];
* |) E' c( O; l6 r
x4=[300.6 243.0 354.1 294.1 361.4];
9 u$ s1 T. {. W+ P
x5=[243.0 354.1 294.1 361.4 333.7];
4 G6 z5 |5 j n7 ^# c9 a' W+ z; `
x6=[354.1 294.1 361.4 333.7 426.4];
; k: @. r& h" ^) q- ]9 _$ ]. P
x7=[294.1 361.4 333.7 426.4 434.4];
* i' [ ^: _( b: x' F# M
x8=[361.4 333.7 426.4 434.4 449.9];
* \) c p5 F& `4 R- z0 g" N7 m+ y
x9=[333.7 426.4 434.4 449.9 431.9];
" c# n! K% i2 A5 {" F
1 g8 y( c/ U( [
P=[x1;x2;x3;x4;x5;x6;x7;x8;x9]';
: {$ H8 i& @7 _( Y' L
%输出数据--以一列作为一个输出数据
) g& ~( ~4 a# F2 K; e- @ y# A
y1=[354.1 294.1 361.4 333.7 426.4];
6 t+ U! n( I7 ~& P" h6 A
y2=[294.1 361.4 333.7 426.4 434.4];
: q! s( o" ?9 y+ u+ h- Z0 C
y3=[361.4 333.7 426.4 434.4 449.9];
. t: I0 v. v4 h9 H3 ~4 Q
y4=[333.7 426.4 434.4 449.9 431.9];
5 |0 u6 n7 g# Y1 G* X
y5=[426.4 434.4 449.9 431.9 454.0];
' b) k$ c; X u2 U% U" a
y6=[434.4 449.9 431.9 454.0 655.6];
/ d9 g. C4 i& }7 M1 X* o& [$ K
y7=[449.9 431.9 454.0 655.6 907.0];
- k! G1 ? \% w2 L( k. ^7 G" S
y8=[431.9 454.0 655.6 907.0 1112.5];
; s6 `6 z$ I9 `, p& y* a: m3 s
y9=[454.0 655.6 907.0 1112.5 1401.1];
2 x% H* C- U2 r) F' S1 S# b9 ?
7 ~: S- d0 b! ~& Q' `
T=[y1;y2;y3;y4;y5;y6;y7;y8;y9]';
7 ^. s. Q6 z j( @ K8 q
: @ C: c) P! Y. d& ~" b# \# I3 D
%归一化
6 }$ C. e- g6 y: u
% [P,minp,maxp,T,mint,maxt] = premnmx(P,T);
1 Y, L6 ~: [4 I/ _
%建立网络
% e3 }. y! _& Z% {! C
%其中[10,3]代表有一个隐含层,里面有10个神经元;“3”代表有三个输出数据
& M, C1 Q& E. O0 [
%{'tansig','purelin'}与[10,3]对应,意思为隐含层 与 输出层
0 N( U7 B) O- c. C, [7 r6 A
%'traingdm' 表示调整权重,缩小误差的数学函数
' f) c6 _( a7 a1 o2 k9 q% o
%↓创建一个新的前向神经网络
' T1 _/ i# O' E/ A$ H d
net = newff(minmax(P),[6,5],{'tansig','purelin'},'traingdm')
A, t/ p/ U% i8 Z
& V; O2 Q( C4 X$ |! I; Y/ m% X3 u
% 当前输入层权值和阈值
# E. {2 `2 A1 z6 i
inputWeights = net.IW(1,1)
, Q2 y) e0 s* ?; {$ q5 O& [
inputbias = net.b(1)
, B; L7 r6 J; m
+ z3 [! H2 |+ \; G
% 当前网络层权值和阈值
' z3 N: H# x! `% A1 G4 M- D3 |
layerWeights = net.LW(2,1)
2 o% G+ M5 L( o5 Y( e3 a
layerbias = net.b(2)
# x- m0 Y* Z- q6 |/ x' j/ W/ B
7 P: C% z& q( M4 [$ @' T' g
% 设置训练参数
1 H8 Z" \+ m* i9 }# W
net.trainParam.show = 50;
" z' t: f' p k$ ]5 e
net.trainParam.lr = 0.05;
& g! t9 R# V2 {5 p) Y$ @
net.trainParam.mc = 0.9;
; }* h3 I0 J' {8 }; D# v4 z+ b
net.trainParam.epochs = 10000; %每计算10000次出一次结果
& T; t ]% z4 q4 O3 x
net.trainParam.goal = 1e-6; %期望达到的误差(认为是合适的误差)
' U- x9 K" z R* I! J
5 P6 i4 K3 D5 z) l1 e; ^
% 调用 TRAINGDM 算法训练 BP 网络
# s% D l7 y$ H- m9 i
[net,tr] = train(net,P,T);
9 e+ f. s) A( G l( g
$ h/ y; Z$ N; s
% 对 BP 网络进行仿真
1 R8 p1 _. J6 Q5 ]% c. m4 Q
A = sim(net,P); %A为输出结果
: D$ t; X& d1 W: G7 ]0 D
- }& G6 n2 f! d2 T7 ~4 L
%反归一化
% c8 _6 k" c t" D% f" b2 O/ d
% A = postmnmx(A,mint,maxt);
% M9 `/ e& K5 E8 {
2 ^5 ^! |" @ U& k! @( h6 \7 A4 C
% 计算仿真误差
$ C4 m% N1 L# s( X" T, t5 ~& z* U# D
E = T-A; %原来的输出 - 训练输出 = 误差
6 n( Y7 Q$ o# V# ?9 r- w
MSE = mse(E) %输出误差
0 P" M- L+ X1 m( _, h p
9 O% x& c8 ?$ x! S/ V U1 B4 i
%下面是输入数据,测试结果
/ V* @$ b7 L% m+ m Z3 Z/ J
x=[454.0 655.6 907.0 1112.5 1401.1]';
+ Y. q3 y! }" n3 l' d/ s- l
Y = sim(net,x)
( L' o8 I' F$ _8 O7 ~3 `
作者:
magic2728
时间:
2013-9-9 13:06
要进行预测,必须有对应的新的输入量,你的在哪里?
作者:
kaito1412
时间:
2013-9-9 18:51
用mapminmax可以对P,T分别归一化
作者:
狼之魂汪洋
时间:
2014-8-11 09:51
不知道你最后是怎么解决的,感觉你最后预测的时候没有把输入数据进行归一化,即要对x进行归一化,再对y进行反归一化,这是我的看法,不知道对不对
欢迎光临 数学建模社区-数学中国 (http://www.madio.net/)
Powered by Discuz! X2.5