QQ登录

只需要一步,快速开始

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

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

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

1189

主题

4

听众

2934

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-8-19 15:20 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
在本文中使用BP神经网络进行数据预测的功能。具体来说,它使用了BP神经网络模型进行公路客运量和公路货运量的预测。这个问题涉及了了解和预测公路客运量和公路货运量的变化趋势。公路客运量指的是公路上人数的运输量,而公路货运量表示公路上货物的运输量。
通过分析与这两个指标相关的数据,如人口数量、机动车数量和公路面积,代码通过BP神经网络模型构建了一个预测模型。预测模型的目标是根据输入的数据(人口数量、机动车数量和公路面积)来预测公路客运量和公路货运量的值。
6 M3 _8 t  L* D, R+ V) h6 M& Y0 X
以下是bp神经网络的简单介绍:7 X9 g' |' @4 A' K
BP神经网络,即反向传播神经网络(Backpropagation Neural Network),是一种常用的人工神经网络模型。它是一种具有前馈和反向传播机制的多层前馈神经网络,是一种有监督的学习算法,适用于解决分类和回归问题。
BP神经网络由输入层、隐藏层和输出层组成,每个层都由多个神经元(节点)组成。每个神经元与上一层和下一层的神经元相连接,并且每条连接都有一个权重。
BP神经网络的学习分为两个过程:前向传播和反向传播。
前向传播:从输入层开始,将输入样本输入网络,经过每一层的神经元的计算,最终得到输出层的输出结果。在前向传播过程中,每个神经元根据其输入信号和权重进行加权求和,并通过激活函数(如sigmoid函数)进行非线性变换,生成该神经元的输出。
反向传播:将网络的输出结果与期望输出进行比较,计算输出误差。然后将误差从输出层向输入层反向传播,根据误差调整网络中的权重。反向传播使用梯度下降算法来最小化误差,通过不断迭代调整权重,使网络的输出逼近期望输出。
在反向传播过程中,首先计算输出层的误差,然后逐层向前计算隐藏层的误差,直到达到输入层。根据误差计算的结果,更新每个连接权重的值,以减小误差。
BP神经网络的训练过程是通过多次迭代更新权重,不断调整网络的连接权重和阈值,使得网络的输出逼近期望输出。网络的训练通常以某个终止准则为条件,如达到预定的训练次数或达到期望的误差阈值。
8 ^' C4 d& S8 _$ V  j2 b
& G2 v) f3 g8 b7 B+ W4 h) f
以下是对给出的代码的详细解释:3 m+ \" W+ T! {: U  P
clc                          % 清屏
; }- l- b6 b* C4 _- w& V0 Lclear all;                  %清除内存以便加快运算速度
5 u+ {3 s) Q# n4 w7 a# lclose all;                  %关闭当前所有figure图像
) h. j" e3 b  ~* o这些代码行清空了 MATLAB 的命令窗口、清除了工作区中的所有变量和关闭了所有图形窗口。
# `% ^, ^# R6 j9 n# n8 e, F4 R4 I( N; a% z; C  n2 y

+ H6 _, p4 x; K/ A* ^SamNum=20;                  %输入样本数量为205 d8 \( U" e: T. U& b& N
TestSamNum=20;              %测试样本数量也是20
6 u! q! |/ _1 G. J* `4 NForcastSamNum=2;            %预测样本数量为2. O' G* ?4 _& }# n3 |3 D
HiddenUnitNum=8;            %中间层隐节点数量取8,比工具箱程序多了1个/ h: E( @/ r2 e. q
InDim=3;                    %网络输入维度为3; c6 |$ z! u; ]' W
OutDim=2;                   %网络输出维度为2; Y' @. x- n1 O* O- ?
定义了样本数量、测试样本数量、预测样本数量以及神经网络的隐层节点数量、输入维度和输出维度。- k0 N; O& z! F1 z- I

1 m' J* b4 ~. s$ x9 o& {/ Z1 ^
! ^  g0 q2 w5 _1 j0 T+ K+ Z/ @%原始数据
6 B5 ?0 m% u/ V2 i$ I%人数(单位:万人)" g6 k" r  f" j) ?9 h( i' j- I
sqrs=[20.55 22.44 25.37 27.13 29.45 30.10 30.96 34.06 36.42 38.09 39.13 39.99 ...* N* f8 B% n+ k7 L: B" I
       41.93 44.59 47.30 52.89 55.73 56.76 59.17 60.63];2 |& r, s7 \8 P4 G4 n; E' y/ {
%机动车数(单位:万辆)
  i" W( ^; j# h$ V% G7 osqjdcs=[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...
; G) P  y% y/ V! Y2 p% r) `        2.7 2.85 2.95 3.1];
+ e; W* g1 I' [& E%公路面积(单位:万平方公里)( a' D3 i$ V- {% y. Q0 ~
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 ... ) Q: |8 \. s8 x6 K% |( j" X% H5 H7 q: S
         0.56 0.59 0.59 0.67 0.69 0.79];
; \2 a3 ?3 d4 K, `1 z%公路客运量(单位:万人)
& z5 G$ E7 L. [5 u1 e5 P" o! O  [glkyl=[5126 6217 7730 9145 10460 11387 12353 15750 18304 19836 21024 19490 20433 ...3 X6 j" V: C% b7 L" N
        22598 25107 33442 36836 40548 42927 43462];3 Z4 Q, x' v6 H2 W: s1 k5 h; _- U
%公路货运量(单位:万吨)3 m% a. k1 |5 ~3 l. o
glhyl=[1237 1379 1385 1399 1663 1714 1834 4322 8132 8936 11099 11203 10524 11115 ...
. X- w5 O6 w3 g& R- _  h, O        13320 16762 18673 20724 20803 21804];
8 ?7 b0 o, J1 C7 p0 ]  F7 tp=[sqrs;sqjdcs;sqglmj];  %输入数据矩阵! E9 O2 r* u3 e- N/ R
t=[glkyl;glhyl];           %目标数据矩阵
1 P; o  a% w! a[SamIn,minp,maxp,tn,mint,maxt]=premnmx(p,t); %原始样本对(输入和输出)初始化
  D  C5 o2 b- Y* s给出了一些原始数据,包括人数、机动车数、公路面积、公路客运量和公路货运量。然后将输入数据矩阵p和目标数据矩阵t进行归一化处理,返回归一化后的样本输入SamIn,归一化参数minp和maxp,以及归一化后的目标输出tn和归一化参数mint和maxt。0 a7 l$ a) Q6 G: d/ }' {
6 O( s, s  g: A; T, ^

+ A1 L9 m$ d9 D% k) n: Xrand('state',sum(100*clock))   %依据系统时钟种子产生随机数         4 k( r+ H1 \" ?3 Y
NoiseVar=0.01;                    %噪声强度为0.01(添加噪声的目的是为了防止网络过度拟合)
6 }* X, i9 J& RNoise=NoiseVar*randn(2,SamNum);   %生成噪声3 k3 W  y. @/ m  H0 C
SamOut=tn + Noise;                   %将噪声添加到输出样本上% _% v0 \! Y& s' a
设置随机数种子并生成一些噪声数据,将这些噪声添加到归一化后的目标数据tn上,得到带噪声的样本输出SamOut。
1 E  j: T0 U) z* O% ?
0 d! o  t# a, U! {" L4 ^: K, E3 n4 m4 l, q
TestSamIn=SamIn;                           %这里取输入样本与测试样本相同因为样本容量偏少
8 k9 E( ?% Z6 ?0 l$ ETestSamOut=SamOut;                         %也取输出样本与测试样本相同3 Q# j9 e3 c( I3 @4 L) l
将用于测试的样本输入TestSamIn设置为与训练样本输入SamIn相同,将用于测试的样本输出TestSamOut设置为与训练样本输出SamOut相同。7 d) ?4 D7 u! `7 ^% u- X

, S6 F5 P1 n7 [% P; l% v: l: m$ ~! x+ Y; x
MaxEpochs=50000;                              %最多训练次数为50000
! Q6 F! ~# E$ P/ K# Klr=0.035;                                       %学习速率为0.035
5 J4 U) L6 ?- c- E; QE0=0.65*10^(-3);                              %目标误差为0.65*10^(-3)
% |* F, L! d3 J0 DW1=0.5*rand(HiddenUnitNum,InDim)-0.1;   %初始化输入层与隐含层之间的权值* H5 t0 [* F  B: G1 X& `
B1=0.5*rand(HiddenUnitNum,1)-0.1;       %初始化输入层与隐含层之间的阈值
( _: M2 x! D, ?W2=0.5*rand(OutDim,HiddenUnitNum)-0.1; %初始化输出层与隐含层之间的权值              
  x/ E. }( C' ]0 W& LB2=0.5*rand(OutDim,1)-0.1;                %初始化输出层与隐含层之间的阈值# @" W0 W8 d" N  g0 ?* m* [" n6 P
定义了最大训练次数MaxEpochs、学习速率lr和目标误差E0。然后,随机地初始化输入层与隐含层之间的权值W1和阈值B1,以及输出层与隐含层之间的权值W2和阈值B2。7 X* t6 ]' W7 }/ @( h

* p4 u7 O% q) E* m; j5 {3 H8 _8 a6 V# s# b2 ~8 V. q9 t
ErrHistory=zeros(MaxEpochs,1);                              %给中间变量预先占据内存% v8 w5 m  Q  R* h3 a
for i=1:MaxEpochs
5 r. F3 b+ D* G  e. ?+ r9 y
- S9 c) u: c* u. |1 ~    HiddenOut=logsig(W1*SamIn+repmat(B1,1,SamNum)); % 隐含层网络输出# ^: e1 T% y0 G' J! w, G
    NetworkOut=W2*HiddenOut+repmat(B2,1,SamNum);    % 输出层网络输出) O$ l$ P% X$ Z
    Error=SamOut-NetworkOut;                       % 实际输出与网络输出之差+ Q0 j# E% V8 M( m
    SSE=sumsqr(Error);                               %能量函数(误差平方和)" ~" \# F8 d4 ~; u5 F
    ErrHistory(i)=SSE;
$ O* v; P! W% {5 a" p6 x* l! U0 t: [9 K6 V
    if SSE<E0,break, end      %如果达到误差要求则跳出学习循环4 ~( Y, x7 u7 @
7 }# W6 f) j+ B% T1 f1 L
    % 以下六行是BP网络最核心的程序% o% [3 K/ j. ?. f2 ?5 A. N, h
    % 他们是权值(阈值)依据能量函数负梯度下降原理所作的每一步动态调整量
" z; `' `# v; m1 S& {0 z    Delta2=Error;
- _# T& u0 b' ^5 H    Delta1=W2'*Delta2.*HiddenOut.*(1-HiddenOut);    1 n( z" {% t7 n6 M( u" G+ }

" C* \" i# R7 m: d1 v' B' F    dW2=Delta2*HiddenOut';
. Q9 Z& [4 ~9 y) O! t    dB2=Delta2*ones(SamNum,1);- D- }0 }5 |: X, @9 c

6 {- V* }- d. C: ~8 p    dW1=Delta1*SamIn';
3 @  F- f+ R0 u3 r& X- g    dB1=Delta1*ones(SamNum,1);9 f7 @8 w6 c/ z  x/ c4 a
    %对输出层与隐含层之间的权值和阈值进行修正
  H3 J9 ^1 I8 Y$ y) m0 J( d2 P0 |  a    W2=W2+lr*dW2;
3 w. W, C( z  G/ v8 I    B2=B2+lr*dB2;$ B6 Y" I. i. ?1 h! Z: `
    %对输入层与隐含层之间的权值和阈值进行修正* \* g- ~3 U& o" S4 Y
    W1=W1+lr*dW1;
3 `+ A8 F8 A! v, R/ e9 Z6 Y    B1=B1+lr*dB1;
/ H' h! x6 w6 r+ V2 ?' `2 o7 D* rend
8 h, L5 l4 v1 |' |* z5 v使用BP算法进行神经网络的训练。通过迭代调整权值和阈值来减小实际输出与期望输出之间的误差。迭代过程中,计算隐含层的输出HiddenOut和输出层的输出NetworkOut,计算误差Error,计算能量函数(误差平方和)SSE,并将其保存在ErrHistory中。如果误差小于目标误差E0,则跳出学习循环。核心的BP算法部分涉及到误差的反向传播和权值、阈值的调整。
+ Z$ f. Y  r7 u5 y: M) v8 S6 w: s  O! ?% g
! w/ W" R3 Y' \2 D
HiddenOut=logsig(W1*SamIn+repmat(B1,1,TestSamNum)); % 隐含层输出最终结果' H8 U1 a, F) D9 a" `$ d
NetworkOut=W2*HiddenOut+repmat(B2,1,TestSamNum);    % 输出层输出最终结果0 v+ J2 f* a1 a6 \/ h8 z5 e6 T
a=postmnmx(NetworkOut,mint,maxt);               % 还原网络输出层的结果
8 B  k# W: e% Dx=1990:2009;                                        % 时间轴刻度
) R: V  E# f4 j! N  enewk=a(1,;                                        % 网络输出客运量
& m$ z) z7 h7 f' snewh=a(2,;                                        % 网络输出货运量9 s) r8 l4 E1 ^: c8 v9 q
figure ;
- N1 A5 g) f% o- A$ M; Ysubplot(2,1,1);plot(x,newk,'r-o',x,glkyl,'b--+')    %绘值公路客运量对比图;, G* l+ I) Z/ h- o  k
legend('网络输出客运量','实际客运量');& D/ Y' }" E! ^. N
xlabel('年份');ylabel('客运量/万人');9 \$ s% S& t3 K
subplot(2,1,2);plot(x,newh,'r-o',x,glhyl,'b--+')     %绘制公路货运量对比图;
, A/ f$ e# L( X& I; W6 F+ qlegend('网络输出货运量','实际货运量');" q2 T. B( |1 M& ~9 T+ Q
xlabel('年份');ylabel('货运量/万吨');6 L( O" f" w% R
使用训练好的神经网络对测试样本进行预测并还原归一化结果。将还原后的网络输出结果与实际数据绘制成图形进行对比展示2 p' O7 i, ]9 |$ f

* `  s9 R  D% M: y3 c$ n: Q, Lpnew=[73.39 75.55* [& N" z. J( D( t7 z3 U
      3.9635 4.0975
( Q5 a- z& l0 O  P* R8 w      0.9880 1.0268];                     %2010年和2011年的相关数据;
& u( O0 C! H( b/ `pnewn=tramnmx(pnew,minp,maxp);         %利用原始输入数据的归一化参数对新数据进行归一化;0 o1 v$ h7 S; x  J
HiddenOut=logsig(W1*pnewn+repmat(B1,1,ForcastSamNum)); % 隐含层输出预测结果& [$ Q8 k  \5 d1 _
anewn=W2*HiddenOut+repmat(B2,1,ForcastSamNum);           % 输出层输出预测结果
9 w: l, V: C9 N4 g%把网络预测得到的数据还原为原始的数量级;  s  k' t: f; J; d5 X4 [( s# P
anew=postmnmx(anewn,mint,maxt);
+ a' }0 f, e( k
8 n  [) v3 S4 Z9 G& D# R( k9 A给出了新的输入数据pnew,对其进行归一化处理得到归一化后的输入数据pnewn。然后,使用训练好的神经网络对归一化后的输入数据进行预测,得到归一化后的预测结果。最后,利用逆归一化操作将预测结果恢复为原始的数量级。( f! N( u2 r; z1 j7 T/ ?6 R& I8 Q
该段代码主要包括数据预处理、神经网络的训练和预测,以及结果的可视化展示。通过训练得到的神经网络,可以对输入数据进行预测并输出相应的结果。
1 k* G6 a0 p. V% D/ C% T% l$ Y. p: s) G/ G
对于代码将以附件形式给出0 X9 j* {1 `/ w0 k1 W- S
- D  r8 x% K6 U

  N/ g+ ?, o& F5 w
; N7 i& \$ n# r! M' t8 _

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-6-16 04:48 , Processed in 0.409252 second(s), 55 queries .

回顶部