QQ登录

只需要一步,快速开始

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

BP神经网络进行数据预测(matlab版)

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

1188

主题

4

听众

2931

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-8-19 15:20 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
在本文中使用BP神经网络进行数据预测的功能。具体来说,它使用了BP神经网络模型进行公路客运量和公路货运量的预测。这个问题涉及了了解和预测公路客运量和公路货运量的变化趋势。公路客运量指的是公路上人数的运输量,而公路货运量表示公路上货物的运输量。
通过分析与这两个指标相关的数据,如人口数量、机动车数量和公路面积,代码通过BP神经网络模型构建了一个预测模型。预测模型的目标是根据输入的数据(人口数量、机动车数量和公路面积)来预测公路客运量和公路货运量的值。

; v: v$ ~( {( O以下是bp神经网络的简单介绍:* i2 L; S7 o" F4 Y' l
BP神经网络,即反向传播神经网络(Backpropagation Neural Network),是一种常用的人工神经网络模型。它是一种具有前馈和反向传播机制的多层前馈神经网络,是一种有监督的学习算法,适用于解决分类和回归问题。
BP神经网络由输入层、隐藏层和输出层组成,每个层都由多个神经元(节点)组成。每个神经元与上一层和下一层的神经元相连接,并且每条连接都有一个权重。
BP神经网络的学习分为两个过程:前向传播和反向传播。
前向传播:从输入层开始,将输入样本输入网络,经过每一层的神经元的计算,最终得到输出层的输出结果。在前向传播过程中,每个神经元根据其输入信号和权重进行加权求和,并通过激活函数(如sigmoid函数)进行非线性变换,生成该神经元的输出。
反向传播:将网络的输出结果与期望输出进行比较,计算输出误差。然后将误差从输出层向输入层反向传播,根据误差调整网络中的权重。反向传播使用梯度下降算法来最小化误差,通过不断迭代调整权重,使网络的输出逼近期望输出。
在反向传播过程中,首先计算输出层的误差,然后逐层向前计算隐藏层的误差,直到达到输入层。根据误差计算的结果,更新每个连接权重的值,以减小误差。
BP神经网络的训练过程是通过多次迭代更新权重,不断调整网络的连接权重和阈值,使得网络的输出逼近期望输出。网络的训练通常以某个终止准则为条件,如达到预定的训练次数或达到期望的误差阈值。

: h* ~5 S: a9 {5 s5 Z
. l4 Z  G- a2 v6 m以下是对给出的代码的详细解释:
: m: ]- m) E# O4 _+ w& Bclc                          % 清屏8 G$ N2 f$ G- }! S. I! O
clear all;                  %清除内存以便加快运算速度
: j, y, H4 O) Z3 bclose all;                  %关闭当前所有figure图像
) @  ]$ P9 Y4 F0 W这些代码行清空了 MATLAB 的命令窗口、清除了工作区中的所有变量和关闭了所有图形窗口。6 S; }( ?( y+ _6 u) l  g+ x0 }& {

! }. z8 P: i% C% R' |+ Z
9 e0 ^* q1 S% d3 H0 Q7 oSamNum=20;                  %输入样本数量为20
" v( y5 r, p3 v0 h2 o  c3 F4 UTestSamNum=20;              %测试样本数量也是20+ L: A( c! V# a3 G$ C
ForcastSamNum=2;            %预测样本数量为2
- V; I- g5 t0 FHiddenUnitNum=8;            %中间层隐节点数量取8,比工具箱程序多了1个! l/ O, B$ A9 A. Q9 T
InDim=3;                    %网络输入维度为31 Q! {: Q) p+ G& e% R
OutDim=2;                   %网络输出维度为2& i+ m! W. B8 f3 J: N' C
定义了样本数量、测试样本数量、预测样本数量以及神经网络的隐层节点数量、输入维度和输出维度。2 X6 ~4 e: O9 Y% {
# y5 V: A( E& Q$ K- V: o  [. |

+ }6 |; H% [9 Q' K7 G3 d1 A  a2 Q%原始数据
2 ]' S9 T& b* a: S* r8 c%人数(单位:万人)
% i' }5 `: `* Q& Y2 Gsqrs=[20.55 22.44 25.37 27.13 29.45 30.10 30.96 34.06 36.42 38.09 39.13 39.99 ...% |. b' I2 p! m, J7 m0 f
       41.93 44.59 47.30 52.89 55.73 56.76 59.17 60.63];
  i& z; D6 ~! P; G# y& Z%机动车数(单位:万辆)! w! w4 H& O8 Y5 Y
sqjdcs=[0.6 0.75 0.85 0.9 1.05 1.35 1.45 1.6 1.7 1.85 2.15 2.2 2.25 2.35 2.5 2.6...2 M  d) d3 V% O4 E; O' H$ a
        2.7 2.85 2.95 3.1];
4 Q1 H3 v$ v5 Y* ]9 D%公路面积(单位:万平方公里)0 z' q9 }" Q4 f0 @6 c# t
sqglmj=[0.09 0.11 0.11 0.14 0.20 0.23 0.23 0.32 0.32 0.34 0.36 0.36 0.38 0.49 ... ) ?8 M$ f  q6 U8 Q! g( C; z
         0.56 0.59 0.59 0.67 0.69 0.79];& l8 c1 q) N6 L
%公路客运量(单位:万人)/ g. x$ H# j: b* F- ~4 v+ V* ~
glkyl=[5126 6217 7730 9145 10460 11387 12353 15750 18304 19836 21024 19490 20433 ...
! A9 r6 ]) ^4 a9 F0 q        22598 25107 33442 36836 40548 42927 43462];
' m% _. w# \. V) l; e* @%公路货运量(单位:万吨); u, @& [" f  X0 ^
glhyl=[1237 1379 1385 1399 1663 1714 1834 4322 8132 8936 11099 11203 10524 11115 ...
9 k2 g$ @* k# L' t5 E        13320 16762 18673 20724 20803 21804];
9 q9 i% L6 x5 Z+ np=[sqrs;sqjdcs;sqglmj];  %输入数据矩阵8 A$ I2 t5 b# I- m% S( p
t=[glkyl;glhyl];           %目标数据矩阵0 C! C  O) O" @, T* s8 y
[SamIn,minp,maxp,tn,mint,maxt]=premnmx(p,t); %原始样本对(输入和输出)初始化2 c5 h6 _( y) \8 E0 K
给出了一些原始数据,包括人数、机动车数、公路面积、公路客运量和公路货运量。然后将输入数据矩阵p和目标数据矩阵t进行归一化处理,返回归一化后的样本输入SamIn,归一化参数minp和maxp,以及归一化后的目标输出tn和归一化参数mint和maxt。
* G5 J4 q0 h# w) z# n8 g* q$ t/ Y5 A6 F2 D: Y' G. Y' u
7 r. C8 k& m, [1 _2 y
rand('state',sum(100*clock))   %依据系统时钟种子产生随机数         
' ?8 Y. b) P. `& ?NoiseVar=0.01;                    %噪声强度为0.01(添加噪声的目的是为了防止网络过度拟合)
& F5 ]! v* ]3 `9 W8 f& g' VNoise=NoiseVar*randn(2,SamNum);   %生成噪声
) k, O  c2 r! _9 g% ?, ^' uSamOut=tn + Noise;                   %将噪声添加到输出样本上
& i! X$ h+ P! l$ q设置随机数种子并生成一些噪声数据,将这些噪声添加到归一化后的目标数据tn上,得到带噪声的样本输出SamOut。7 T) G" H2 C+ ^/ a' {8 p

! d% y  C. e- \7 R1 U5 B; U
+ a5 M. q/ h7 T: R3 b$ RTestSamIn=SamIn;                           %这里取输入样本与测试样本相同因为样本容量偏少* g# q+ h6 R+ `: u  U- p& Z
TestSamOut=SamOut;                         %也取输出样本与测试样本相同
- B, w9 G: m. F将用于测试的样本输入TestSamIn设置为与训练样本输入SamIn相同,将用于测试的样本输出TestSamOut设置为与训练样本输出SamOut相同。
$ V: }! |1 a2 B1 U6 Y) r% A! `0 n& B$ z2 E- Z. r

; r8 w5 K# @" O% k. U, R; y& JMaxEpochs=50000;                              %最多训练次数为500001 I/ a- f& q" Z- A1 {: H# D
lr=0.035;                                       %学习速率为0.035! E0 \( {4 _9 V  N+ E
E0=0.65*10^(-3);                              %目标误差为0.65*10^(-3)
9 x$ J, Y# v+ D0 @7 bW1=0.5*rand(HiddenUnitNum,InDim)-0.1;   %初始化输入层与隐含层之间的权值
, J, O/ c+ ]6 g4 H$ ^" l3 F7 LB1=0.5*rand(HiddenUnitNum,1)-0.1;       %初始化输入层与隐含层之间的阈值
, A) s' L# T% l+ R7 @4 B" K, G# F% JW2=0.5*rand(OutDim,HiddenUnitNum)-0.1; %初始化输出层与隐含层之间的权值              
% u1 E; ~( q2 P- ?. _B2=0.5*rand(OutDim,1)-0.1;                %初始化输出层与隐含层之间的阈值
, m, E; O: ?* S6 r: j" y定义了最大训练次数MaxEpochs、学习速率lr和目标误差E0。然后,随机地初始化输入层与隐含层之间的权值W1和阈值B1,以及输出层与隐含层之间的权值W2和阈值B2。! J$ b  F. _6 `! E$ E

/ ~& B' H/ x2 x9 [- d) _5 V; f
8 y& @) d  \: b4 nErrHistory=zeros(MaxEpochs,1);                              %给中间变量预先占据内存2 V+ j. c. c5 Q) X, E& i, y
for i=1:MaxEpochs3 t6 A; c- D2 m7 M' [9 e- w

6 M1 v1 n5 o, N' Z7 h. E    HiddenOut=logsig(W1*SamIn+repmat(B1,1,SamNum)); % 隐含层网络输出
* |1 u! r% c" f/ T/ u5 f    NetworkOut=W2*HiddenOut+repmat(B2,1,SamNum);    % 输出层网络输出
1 _4 Q3 q. z/ G9 M    Error=SamOut-NetworkOut;                       % 实际输出与网络输出之差. ]; y0 w1 B$ R& e3 u
    SSE=sumsqr(Error);                               %能量函数(误差平方和)! G+ @& v' s5 n8 v- h* o
    ErrHistory(i)=SSE;
, r5 P1 d7 c" [  z7 S
% _% X0 B2 k$ q/ M6 m0 m" h" T    if SSE<E0,break, end      %如果达到误差要求则跳出学习循环* [* A" S+ B/ O' ?7 ~/ W
# x+ g- w0 M6 \4 o8 ~
    % 以下六行是BP网络最核心的程序
/ P, k9 o) I  m. {    % 他们是权值(阈值)依据能量函数负梯度下降原理所作的每一步动态调整量9 E' W3 K; w3 A" Y0 F0 r& X7 s
    Delta2=Error;  r, @% [/ a8 R; M! Y& C7 t, [
    Delta1=W2'*Delta2.*HiddenOut.*(1-HiddenOut);    8 G1 x( B: a% S. s

! `: p- d/ |% {8 f! v6 o- x; R    dW2=Delta2*HiddenOut';6 G5 B7 E* \, L5 Q; \  ^" X: i# W6 z
    dB2=Delta2*ones(SamNum,1);
& R9 B; i# _  X: r, g. c! h5 |* x: k! j& Q9 o6 P
    dW1=Delta1*SamIn';
$ a* T) ^" }' ]$ r( W/ z    dB1=Delta1*ones(SamNum,1);
; K. p6 s9 \2 O4 F0 l& a    %对输出层与隐含层之间的权值和阈值进行修正
& g, R. e5 r# C' y2 _    W2=W2+lr*dW2;
% g) o, f8 d% e    B2=B2+lr*dB2;7 w8 U' N; s% U9 O
    %对输入层与隐含层之间的权值和阈值进行修正
" G$ ]& Q3 F* T$ g8 N    W1=W1+lr*dW1;
7 g( Q) P6 N/ T6 k    B1=B1+lr*dB1;7 j, X# g" A8 s5 H; \$ `* M
end6 \1 M  h9 H6 b  w, @
使用BP算法进行神经网络的训练。通过迭代调整权值和阈值来减小实际输出与期望输出之间的误差。迭代过程中,计算隐含层的输出HiddenOut和输出层的输出NetworkOut,计算误差Error,计算能量函数(误差平方和)SSE,并将其保存在ErrHistory中。如果误差小于目标误差E0,则跳出学习循环。核心的BP算法部分涉及到误差的反向传播和权值、阈值的调整。+ g$ u- |/ ?8 A, s2 h
/ N4 B! N- n, Z1 _* ~4 U# }

( z8 R1 r5 p% y( k" R! ~HiddenOut=logsig(W1*SamIn+repmat(B1,1,TestSamNum)); % 隐含层输出最终结果+ G' D. a- B, {! L
NetworkOut=W2*HiddenOut+repmat(B2,1,TestSamNum);    % 输出层输出最终结果7 A$ @/ J' ~- ^1 e! Y0 [) ~
a=postmnmx(NetworkOut,mint,maxt);               % 还原网络输出层的结果
- x* [, h) a) H- x5 f* ex=1990:2009;                                        % 时间轴刻度
$ h9 @" D+ a6 q7 j) ^  R; hnewk=a(1,;                                        % 网络输出客运量
- ~' G$ F  c$ r8 b' |newh=a(2,;                                        % 网络输出货运量1 {8 o* W* D, s% r5 r* }
figure ;6 w6 v" T- |. R; V( E3 W
subplot(2,1,1);plot(x,newk,'r-o',x,glkyl,'b--+')    %绘值公路客运量对比图;
- T" ^! m5 d+ @2 a$ T' Qlegend('网络输出客运量','实际客运量');5 N/ i8 H- Z! B/ O# L4 f; ^5 o
xlabel('年份');ylabel('客运量/万人');
$ Y/ I! _6 j2 n% bsubplot(2,1,2);plot(x,newh,'r-o',x,glhyl,'b--+')     %绘制公路货运量对比图;
5 V  a! R3 K2 {* c: Y' Y) nlegend('网络输出货运量','实际货运量');
$ q$ r7 I5 i  A& f/ }7 K; _xlabel('年份');ylabel('货运量/万吨');5 {1 P1 h0 p& C2 c+ w/ U
使用训练好的神经网络对测试样本进行预测并还原归一化结果。将还原后的网络输出结果与实际数据绘制成图形进行对比展示* m1 P9 V9 M  [, X) q+ ^8 a/ O! q
% t8 b" u2 m, Z+ G
pnew=[73.39 75.555 }5 U1 M. L3 N1 u$ j0 _& e
      3.9635 4.09759 o' `8 S) J: o9 _+ ?
      0.9880 1.0268];                     %2010年和2011年的相关数据;
' t" ~' o4 G, X2 hpnewn=tramnmx(pnew,minp,maxp);         %利用原始输入数据的归一化参数对新数据进行归一化;
* X2 C2 S8 h! Y0 F7 WHiddenOut=logsig(W1*pnewn+repmat(B1,1,ForcastSamNum)); % 隐含层输出预测结果
3 D7 e  V% N/ \) manewn=W2*HiddenOut+repmat(B2,1,ForcastSamNum);           % 输出层输出预测结果1 L8 I- m  x' N* A. y
%把网络预测得到的数据还原为原始的数量级;
' B. U, w. r, Q, t; z% e% ranew=postmnmx(anewn,mint,maxt);2 K4 u7 Z- _- z1 n3 j! n

6 o5 t# K' p  J# N9 l给出了新的输入数据pnew,对其进行归一化处理得到归一化后的输入数据pnewn。然后,使用训练好的神经网络对归一化后的输入数据进行预测,得到归一化后的预测结果。最后,利用逆归一化操作将预测结果恢复为原始的数量级。. [, V1 g, [+ i* t
该段代码主要包括数据预处理、神经网络的训练和预测,以及结果的可视化展示。通过训练得到的神经网络,可以对输入数据进行预测并输出相应的结果。  b% B) L& r- _& W: s
, y* p! I' p% q
对于代码将以附件形式给出2 k' n3 L$ s! h( J+ N  B
4 [( W; s- t8 l
+ p* b. ^1 P% }$ h

# F, [6 k) h+ g' }, o' r  m4 ^

bp_theroy.rar

2.23 KB, 下载次数: 0, 下载积分: 体力 -2 点

售价: 3 点体力  [记录]  [购买]

zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

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

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

蒙公网安备 15010502000194号

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

GMT+8, 2026-5-25 16:48 , Processed in 0.558981 second(s), 55 queries .

回顶部