QQ登录

只需要一步,快速开始

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

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

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

1189

主题

4

听众

2934

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-8-19 15:20 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
在本文中使用BP神经网络进行数据预测的功能。具体来说,它使用了BP神经网络模型进行公路客运量和公路货运量的预测。这个问题涉及了了解和预测公路客运量和公路货运量的变化趋势。公路客运量指的是公路上人数的运输量,而公路货运量表示公路上货物的运输量。
通过分析与这两个指标相关的数据,如人口数量、机动车数量和公路面积,代码通过BP神经网络模型构建了一个预测模型。预测模型的目标是根据输入的数据(人口数量、机动车数量和公路面积)来预测公路客运量和公路货运量的值。
! E0 d5 J  D+ v8 |  ^
以下是bp神经网络的简单介绍:7 K4 Y$ Z; ^% K
BP神经网络,即反向传播神经网络(Backpropagation Neural Network),是一种常用的人工神经网络模型。它是一种具有前馈和反向传播机制的多层前馈神经网络,是一种有监督的学习算法,适用于解决分类和回归问题。
BP神经网络由输入层、隐藏层和输出层组成,每个层都由多个神经元(节点)组成。每个神经元与上一层和下一层的神经元相连接,并且每条连接都有一个权重。
BP神经网络的学习分为两个过程:前向传播和反向传播。
前向传播:从输入层开始,将输入样本输入网络,经过每一层的神经元的计算,最终得到输出层的输出结果。在前向传播过程中,每个神经元根据其输入信号和权重进行加权求和,并通过激活函数(如sigmoid函数)进行非线性变换,生成该神经元的输出。
反向传播:将网络的输出结果与期望输出进行比较,计算输出误差。然后将误差从输出层向输入层反向传播,根据误差调整网络中的权重。反向传播使用梯度下降算法来最小化误差,通过不断迭代调整权重,使网络的输出逼近期望输出。
在反向传播过程中,首先计算输出层的误差,然后逐层向前计算隐藏层的误差,直到达到输入层。根据误差计算的结果,更新每个连接权重的值,以减小误差。
BP神经网络的训练过程是通过多次迭代更新权重,不断调整网络的连接权重和阈值,使得网络的输出逼近期望输出。网络的训练通常以某个终止准则为条件,如达到预定的训练次数或达到期望的误差阈值。
" q$ g2 a5 e- T# R% p" N1 J

6 K( }' |% P+ E) {以下是对给出的代码的详细解释:
- h8 ~8 \9 w8 S$ w  Q! o; F9 Oclc                          % 清屏
. T, G5 B) ?% `) x! V. ~6 c! l* j, zclear all;                  %清除内存以便加快运算速度. h( |: ?0 E/ |+ e, F
close all;                  %关闭当前所有figure图像! U1 y9 }0 i4 x  x, m
这些代码行清空了 MATLAB 的命令窗口、清除了工作区中的所有变量和关闭了所有图形窗口。
/ Q( ]6 c1 v, }3 z  n. A8 q; q
6 d" n; B5 t) [8 a) [" f" A) m+ N2 o" v/ B
SamNum=20;                  %输入样本数量为20
- @/ f& T) r5 S& ]7 W/ E0 b! [TestSamNum=20;              %测试样本数量也是20+ Y. ^9 c/ ]9 [3 a
ForcastSamNum=2;            %预测样本数量为2& \' M$ u/ M3 w2 V0 t" j5 Q5 T
HiddenUnitNum=8;            %中间层隐节点数量取8,比工具箱程序多了1个
0 b; C" d( W9 ]+ e. aInDim=3;                    %网络输入维度为3
  o7 j+ X+ i* D( O. _; OOutDim=2;                   %网络输出维度为2
! C& p, Z$ N7 p( z/ m+ b2 \定义了样本数量、测试样本数量、预测样本数量以及神经网络的隐层节点数量、输入维度和输出维度。, C4 @+ j' R& W/ \4 H
0 w" S/ O: ]3 l% X! O7 c3 ~
! v+ n6 p' R) K( ~2 {0 m
%原始数据 " U4 b& o: u8 p1 }' S) Z
%人数(单位:万人)
0 U( x3 m8 a% Osqrs=[20.55 22.44 25.37 27.13 29.45 30.10 30.96 34.06 36.42 38.09 39.13 39.99 ...
2 ^5 [  N- B5 j0 L' I       41.93 44.59 47.30 52.89 55.73 56.76 59.17 60.63];+ A% t% }0 w, i  m; Z3 Z
%机动车数(单位:万辆)7 ]: Q" x' L7 N% l1 \
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...
- j+ M  X$ ~3 X6 A) t6 W        2.7 2.85 2.95 3.1];
& F" c3 `- K3 V( C' v%公路面积(单位:万平方公里)/ a; {! p; R9 |: Q$ w
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 ... / a0 r: C) m" j! L( p
         0.56 0.59 0.59 0.67 0.69 0.79];
6 J1 o* v2 ]$ g4 n" Q- J' S! w* C%公路客运量(单位:万人)
; _; _$ M" x1 W) \glkyl=[5126 6217 7730 9145 10460 11387 12353 15750 18304 19836 21024 19490 20433 ...4 d4 q: M/ _0 ~7 v
        22598 25107 33442 36836 40548 42927 43462];0 G; K0 r. K5 k) w1 n& f$ X" P
%公路货运量(单位:万吨)
5 H3 f. j2 O9 V* Yglhyl=[1237 1379 1385 1399 1663 1714 1834 4322 8132 8936 11099 11203 10524 11115 ...
: S2 G: A: S- p        13320 16762 18673 20724 20803 21804];  H7 ~- ?* ?+ y6 u1 J4 Z
p=[sqrs;sqjdcs;sqglmj];  %输入数据矩阵4 ^' [& n6 e3 w8 q
t=[glkyl;glhyl];           %目标数据矩阵
2 n* `4 P' T+ @8 b[SamIn,minp,maxp,tn,mint,maxt]=premnmx(p,t); %原始样本对(输入和输出)初始化
5 k" n5 Z! H" j给出了一些原始数据,包括人数、机动车数、公路面积、公路客运量和公路货运量。然后将输入数据矩阵p和目标数据矩阵t进行归一化处理,返回归一化后的样本输入SamIn,归一化参数minp和maxp,以及归一化后的目标输出tn和归一化参数mint和maxt。
6 D4 d4 x* R! O/ z9 S
' R2 O7 R+ \! b' E- {9 m4 }  `% i/ R* m5 q
rand('state',sum(100*clock))   %依据系统时钟种子产生随机数         
1 q! {) k  D# M6 z; uNoiseVar=0.01;                    %噪声强度为0.01(添加噪声的目的是为了防止网络过度拟合)4 e! v4 c% m9 ^4 [
Noise=NoiseVar*randn(2,SamNum);   %生成噪声: \, M! z, \1 x" S* J
SamOut=tn + Noise;                   %将噪声添加到输出样本上( \9 V8 ?- w2 \3 p* w* b  H/ L
设置随机数种子并生成一些噪声数据,将这些噪声添加到归一化后的目标数据tn上,得到带噪声的样本输出SamOut。/ e5 d- a9 r  C0 l* p7 d3 f9 s
9 g# J' }/ B) m3 z8 p

- |7 e8 A" ~( Q  \5 gTestSamIn=SamIn;                           %这里取输入样本与测试样本相同因为样本容量偏少
& e: D6 N2 R5 @TestSamOut=SamOut;                         %也取输出样本与测试样本相同
8 G8 U* n& ~1 H) {/ h$ Q4 v2 v将用于测试的样本输入TestSamIn设置为与训练样本输入SamIn相同,将用于测试的样本输出TestSamOut设置为与训练样本输出SamOut相同。% @* L0 N% E6 r8 H

" w/ R" C3 L& w2 d- e$ i5 j6 _) L$ g1 ]$ l
MaxEpochs=50000;                              %最多训练次数为50000
- K7 L, A+ \3 C/ ?5 G' q/ |0 \lr=0.035;                                       %学习速率为0.035
  q0 ?  E+ j7 M, X+ f. z7 oE0=0.65*10^(-3);                              %目标误差为0.65*10^(-3)
( ~0 e- e8 m8 T( b" \2 ?; _W1=0.5*rand(HiddenUnitNum,InDim)-0.1;   %初始化输入层与隐含层之间的权值3 W9 y7 p, ~, s2 x* w9 R# j
B1=0.5*rand(HiddenUnitNum,1)-0.1;       %初始化输入层与隐含层之间的阈值
, e5 B6 i3 z5 |- E- y( D6 cW2=0.5*rand(OutDim,HiddenUnitNum)-0.1; %初始化输出层与隐含层之间的权值              
# [# ?6 z& B; A, @. V5 TB2=0.5*rand(OutDim,1)-0.1;                %初始化输出层与隐含层之间的阈值! h  x* S. W: L0 T: H/ ^. Z7 p
定义了最大训练次数MaxEpochs、学习速率lr和目标误差E0。然后,随机地初始化输入层与隐含层之间的权值W1和阈值B1,以及输出层与隐含层之间的权值W2和阈值B2。) ]' u/ Q. a2 Q1 \2 d+ \
6 U1 ^0 ^% x7 s3 V& Y

; d7 u4 q* K4 f" }7 y8 KErrHistory=zeros(MaxEpochs,1);                              %给中间变量预先占据内存4 M- {# C0 F6 Z1 w9 ~
for i=1:MaxEpochs  w, l& ?  A. G/ h- a0 y$ S5 y" }

3 r- }; I0 O) v& N( V3 V    HiddenOut=logsig(W1*SamIn+repmat(B1,1,SamNum)); % 隐含层网络输出
! l$ L& ~5 M# v2 `* Y    NetworkOut=W2*HiddenOut+repmat(B2,1,SamNum);    % 输出层网络输出
, c3 R3 x3 |/ b; h7 ^9 h    Error=SamOut-NetworkOut;                       % 实际输出与网络输出之差+ f3 f' v: j% y3 a0 l" o. r
    SSE=sumsqr(Error);                               %能量函数(误差平方和)
8 u, v; S$ u" N  V: v    ErrHistory(i)=SSE;5 r" V8 ^" @! `. t/ n  `
/ U5 G1 g- I6 M. ?
    if SSE<E0,break, end      %如果达到误差要求则跳出学习循环& t$ p2 G* o. W) |0 w5 x( v: m

) f" a2 @; [- d3 W! S3 J    % 以下六行是BP网络最核心的程序, g. N& c+ Y& q0 c! d
    % 他们是权值(阈值)依据能量函数负梯度下降原理所作的每一步动态调整量% N( u2 N( O9 w3 \- D
    Delta2=Error;
7 T7 v! }! n- F    Delta1=W2'*Delta2.*HiddenOut.*(1-HiddenOut);   
: J5 P5 K6 a2 @' ?8 ^/ _- s; Y: \7 m  `1 y$ H8 j+ h; M4 k/ w* q
    dW2=Delta2*HiddenOut';9 l5 l' q9 D# Q" V% |  g8 ~
    dB2=Delta2*ones(SamNum,1);
/ Z" B2 V/ `& C- h/ L
2 N5 x; d; J+ t# A  d. _% s: x    dW1=Delta1*SamIn';
: N9 g: J* Q% |/ C& L; c+ [    dB1=Delta1*ones(SamNum,1);
! n6 G) V/ Q  m$ b    %对输出层与隐含层之间的权值和阈值进行修正8 L/ M5 c0 D: _) Q7 z! R# U
    W2=W2+lr*dW2;$ _9 A4 a7 m; @3 I3 \( ^' N
    B2=B2+lr*dB2;& ?* W2 m  w1 F0 E% a* e
    %对输入层与隐含层之间的权值和阈值进行修正
8 ?) I9 U8 y" f) \; Q# a    W1=W1+lr*dW1;
- y+ ?( _4 w( `, O    B1=B1+lr*dB1;: Q1 A  T2 k# s7 T
end
( c3 c! g' s1 k; I0 }' E- m使用BP算法进行神经网络的训练。通过迭代调整权值和阈值来减小实际输出与期望输出之间的误差。迭代过程中,计算隐含层的输出HiddenOut和输出层的输出NetworkOut,计算误差Error,计算能量函数(误差平方和)SSE,并将其保存在ErrHistory中。如果误差小于目标误差E0,则跳出学习循环。核心的BP算法部分涉及到误差的反向传播和权值、阈值的调整。
+ y7 r0 S9 t" w! d* G) c  Y4 A; e" E- I3 B; O
4 m, W8 h% ~: P1 b
HiddenOut=logsig(W1*SamIn+repmat(B1,1,TestSamNum)); % 隐含层输出最终结果; g# p' k: O; Z* R
NetworkOut=W2*HiddenOut+repmat(B2,1,TestSamNum);    % 输出层输出最终结果
9 X7 Q( u9 n. a% Ea=postmnmx(NetworkOut,mint,maxt);               % 还原网络输出层的结果3 l: n) d* l3 l/ g  o* h/ ]# i6 y( l
x=1990:2009;                                        % 时间轴刻度( |7 b. R8 a5 h7 P
newk=a(1,;                                        % 网络输出客运量/ o( {* X/ O" ^: U9 N8 |
newh=a(2,;                                        % 网络输出货运量
- Z1 M( A8 f7 n' q1 F& z% K4 dfigure ;
- F) U, f7 ^/ H4 psubplot(2,1,1);plot(x,newk,'r-o',x,glkyl,'b--+')    %绘值公路客运量对比图;1 ^' G# }* k4 W4 {+ x$ l4 t/ p0 `
legend('网络输出客运量','实际客运量');8 \  b# b, S" w& U- r! i4 P
xlabel('年份');ylabel('客运量/万人');1 p" k' C5 ?" V. w
subplot(2,1,2);plot(x,newh,'r-o',x,glhyl,'b--+')     %绘制公路货运量对比图;9 h# W  o- G- x3 Z# [
legend('网络输出货运量','实际货运量');" o$ ?+ n+ M+ i
xlabel('年份');ylabel('货运量/万吨');! ^% s7 n- Z& X- ^  A, ^5 [
使用训练好的神经网络对测试样本进行预测并还原归一化结果。将还原后的网络输出结果与实际数据绘制成图形进行对比展示+ W4 m9 V2 k$ l1 E8 V
2 g$ F! l1 R  q9 J
pnew=[73.39 75.55) g( D( D( G7 d. M1 n9 L3 j
      3.9635 4.0975
5 b0 y1 e# Y7 u7 w      0.9880 1.0268];                     %2010年和2011年的相关数据;
' E7 W3 b; k( y9 W! @" Zpnewn=tramnmx(pnew,minp,maxp);         %利用原始输入数据的归一化参数对新数据进行归一化;8 |" o5 T; E/ \( \
HiddenOut=logsig(W1*pnewn+repmat(B1,1,ForcastSamNum)); % 隐含层输出预测结果
8 \  s* T: R/ W! y; }* m. {anewn=W2*HiddenOut+repmat(B2,1,ForcastSamNum);           % 输出层输出预测结果" `4 ?5 k! W( x* N5 a! l/ T0 w
%把网络预测得到的数据还原为原始的数量级;1 D# M8 c! {% |8 V' O8 t: s7 Z8 m" i
anew=postmnmx(anewn,mint,maxt);, q. Q$ `* A/ z  a

; ?" V9 x' @& O给出了新的输入数据pnew,对其进行归一化处理得到归一化后的输入数据pnewn。然后,使用训练好的神经网络对归一化后的输入数据进行预测,得到归一化后的预测结果。最后,利用逆归一化操作将预测结果恢复为原始的数量级。
1 q" ^+ g1 t: ?3 T2 p* A该段代码主要包括数据预处理、神经网络的训练和预测,以及结果的可视化展示。通过训练得到的神经网络,可以对输入数据进行预测并输出相应的结果。
9 f3 Z" }/ e1 P2 [: z# y
% U; Z) b5 M3 j) a# j对于代码将以附件形式给出
; q+ Z+ r% N3 I9 x$ D3 B$ S9 b3 E5 `
  @0 u- c, q( \! {: J% c' |
% k( Q$ g0 d; Q

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-14 09:46 , Processed in 0.423668 second(s), 55 queries .

回顶部