QQ登录

只需要一步,快速开始

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

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

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

1186

主题

4

听众

2922

积分

该用户从未签到

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

5 T+ {+ w2 r6 ^# j5 I* R& E6 M* o0 k* o/ K3 |
以下是对给出的代码的详细解释:# L6 O: p% u6 a( p. w( s# l+ P
clc                          % 清屏! k+ O/ U5 B/ F8 W
clear all;                  %清除内存以便加快运算速度5 @0 O0 a$ ^  ~, k% I% L
close all;                  %关闭当前所有figure图像
; V7 _; Y4 q2 e4 r0 H4 E8 F这些代码行清空了 MATLAB 的命令窗口、清除了工作区中的所有变量和关闭了所有图形窗口。' j1 s5 W+ Q# G4 X  v- I% v
2 x' N0 P& G8 E' L: J

7 `0 @+ i% X3 ^) W( g5 sSamNum=20;                  %输入样本数量为200 K  C) g$ u! o' \7 E: |, ^
TestSamNum=20;              %测试样本数量也是20
6 M- K0 j' d3 ~+ P/ g7 MForcastSamNum=2;            %预测样本数量为2
" t& G3 T( d1 FHiddenUnitNum=8;            %中间层隐节点数量取8,比工具箱程序多了1个5 Z7 Y# ]) t% _. \+ D
InDim=3;                    %网络输入维度为3# v, b8 D3 E. ?' ?& A$ t% h
OutDim=2;                   %网络输出维度为2
: ~4 G* R* Y0 x( s" y% i) n+ s定义了样本数量、测试样本数量、预测样本数量以及神经网络的隐层节点数量、输入维度和输出维度。( S5 b+ Q1 B# ^. Y/ V4 g+ _
) @+ C+ s* g; F2 b9 u

% v1 I/ a2 ~  E) H/ E- b2 d%原始数据
+ N+ H. i( a+ n1 H1 o%人数(单位:万人)2 H/ J6 \5 u1 W* g7 v
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 ...8 f, Q. s9 x8 Q$ i% I8 x
       41.93 44.59 47.30 52.89 55.73 56.76 59.17 60.63];' t; r2 w1 H; h* f' V; t1 a4 P
%机动车数(单位:万辆)
8 K+ \- F; G, _+ b, asqjdcs=[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...( t# s! l4 _8 k7 q1 c# j0 ~) m- R
        2.7 2.85 2.95 3.1];
) ~5 @7 x) a) f$ c%公路面积(单位:万平方公里)7 P) e7 U/ t# z: M" o
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 ...
. T/ r$ _+ A) E! H9 R         0.56 0.59 0.59 0.67 0.69 0.79];
5 I( l& S/ E! Y% w7 f! y6 ?7 I$ `%公路客运量(单位:万人)
/ ]2 \* [% y# i' Aglkyl=[5126 6217 7730 9145 10460 11387 12353 15750 18304 19836 21024 19490 20433 ...
; G) l9 d3 _$ t5 z! I- K& W        22598 25107 33442 36836 40548 42927 43462];) s: R, V# C9 t
%公路货运量(单位:万吨)
  A; g" ]- D- y4 B  ]$ G* a, I; [glhyl=[1237 1379 1385 1399 1663 1714 1834 4322 8132 8936 11099 11203 10524 11115 ...
% R. Z) b* `8 A" s% F* m# i        13320 16762 18673 20724 20803 21804];' B8 _' f4 N+ c( w
p=[sqrs;sqjdcs;sqglmj];  %输入数据矩阵) h& q* A; k& S5 P* P5 g8 V
t=[glkyl;glhyl];           %目标数据矩阵; q: S2 h. c4 L9 c7 |
[SamIn,minp,maxp,tn,mint,maxt]=premnmx(p,t); %原始样本对(输入和输出)初始化
7 x5 p9 ?7 r8 l3 L给出了一些原始数据,包括人数、机动车数、公路面积、公路客运量和公路货运量。然后将输入数据矩阵p和目标数据矩阵t进行归一化处理,返回归一化后的样本输入SamIn,归一化参数minp和maxp,以及归一化后的目标输出tn和归一化参数mint和maxt。- z4 U) j9 f1 a9 L9 ^

8 v* r& \+ c: n( y& M2 l9 A5 i3 x& c- G& \( K% ^3 v- A
rand('state',sum(100*clock))   %依据系统时钟种子产生随机数         
; ^* j% d- l' zNoiseVar=0.01;                    %噪声强度为0.01(添加噪声的目的是为了防止网络过度拟合)% S1 ]  S7 W! T8 H
Noise=NoiseVar*randn(2,SamNum);   %生成噪声
/ \9 Q5 m9 u3 N: a6 ISamOut=tn + Noise;                   %将噪声添加到输出样本上% l- Z) i) F3 ~& f$ J* r
设置随机数种子并生成一些噪声数据,将这些噪声添加到归一化后的目标数据tn上,得到带噪声的样本输出SamOut。# i' g, _: ]- a
6 Q0 P, A5 q  e

5 t% y- K/ a/ t" ^6 HTestSamIn=SamIn;                           %这里取输入样本与测试样本相同因为样本容量偏少
+ y3 x3 ?1 Z' j( Z" MTestSamOut=SamOut;                         %也取输出样本与测试样本相同6 h! ]- X$ g: h. S/ D, y+ {' K! I
将用于测试的样本输入TestSamIn设置为与训练样本输入SamIn相同,将用于测试的样本输出TestSamOut设置为与训练样本输出SamOut相同。# X; N4 r2 H, K2 q+ s
# I5 d$ V. ~. |4 W7 ]0 V
- B$ S+ G& _! T2 B1 Y8 S
MaxEpochs=50000;                              %最多训练次数为50000
  }  s! ~/ r" k6 `. |8 o' klr=0.035;                                       %学习速率为0.035
# y9 A) W0 |1 h/ vE0=0.65*10^(-3);                              %目标误差为0.65*10^(-3)3 P" Q2 N, p9 _: }$ c& P$ @
W1=0.5*rand(HiddenUnitNum,InDim)-0.1;   %初始化输入层与隐含层之间的权值& h2 t3 |* ^, m3 o4 a
B1=0.5*rand(HiddenUnitNum,1)-0.1;       %初始化输入层与隐含层之间的阈值+ B. x- W6 g1 D
W2=0.5*rand(OutDim,HiddenUnitNum)-0.1; %初始化输出层与隐含层之间的权值              / N5 `/ \$ u& G1 S, X+ N
B2=0.5*rand(OutDim,1)-0.1;                %初始化输出层与隐含层之间的阈值" m3 j$ q& z, |) k
定义了最大训练次数MaxEpochs、学习速率lr和目标误差E0。然后,随机地初始化输入层与隐含层之间的权值W1和阈值B1,以及输出层与隐含层之间的权值W2和阈值B2。
2 x$ k: A# B2 {; l0 b! c& ]  h
2 G9 b+ k; i8 Y; ^; M( o5 `7 \2 X% i  }6 l0 ^5 y' B8 h- n
ErrHistory=zeros(MaxEpochs,1);                              %给中间变量预先占据内存
0 I& a; l! a$ v: c( @. Xfor i=1:MaxEpochs
  i  C( m4 Q. v5 d" n" _3 h; `/ N3 S& X- ]+ t
    HiddenOut=logsig(W1*SamIn+repmat(B1,1,SamNum)); % 隐含层网络输出7 ~; z9 ^4 b+ t6 J% k8 }/ }% V
    NetworkOut=W2*HiddenOut+repmat(B2,1,SamNum);    % 输出层网络输出
+ v! q6 S/ R) j7 y% C    Error=SamOut-NetworkOut;                       % 实际输出与网络输出之差& V# @4 J! T, O( t# C0 y# |7 U
    SSE=sumsqr(Error);                               %能量函数(误差平方和)
, W1 z) D! g% W1 s  K# }    ErrHistory(i)=SSE;. V/ S- T  X3 p: S% L

/ L5 ?  g' U2 T! q5 x; u    if SSE<E0,break, end      %如果达到误差要求则跳出学习循环% O- L2 o- r+ ~" N8 j
8 h9 I* o( w" y7 w* N5 m
    % 以下六行是BP网络最核心的程序- A  f3 j/ [5 e5 e+ E0 V. U
    % 他们是权值(阈值)依据能量函数负梯度下降原理所作的每一步动态调整量
& U: |) z0 K- M" Z+ V! k3 x    Delta2=Error;& D& ]9 h2 b& ~0 s8 ^# b' K
    Delta1=W2'*Delta2.*HiddenOut.*(1-HiddenOut);   
$ J# {# U: Q7 E8 P; ~+ z; I5 L2 h/ Y: e4 \
    dW2=Delta2*HiddenOut';9 _3 J# v+ E* X- O
    dB2=Delta2*ones(SamNum,1);
+ E8 l; y* g+ I5 {8 w2 c' C
) H1 r! N4 Y) c8 {" S( V$ s8 S    dW1=Delta1*SamIn';
* |* J! n2 T% o# Y1 x    dB1=Delta1*ones(SamNum,1);" Y. s1 @4 K* Z8 a/ G
    %对输出层与隐含层之间的权值和阈值进行修正
; `& }; s3 z- j7 D! s$ z! X( B( o* W    W2=W2+lr*dW2;
$ S  S  A- c& G( U* v9 r  S) \    B2=B2+lr*dB2;6 a  w) X% I- ?: F6 a
    %对输入层与隐含层之间的权值和阈值进行修正
* t. T5 ~! I) J7 a    W1=W1+lr*dW1;) I9 P. K9 a( G1 h& C
    B1=B1+lr*dB1;
& g0 d. ?1 c( i- p& x6 oend
4 [7 Q6 r1 R9 h" S( k9 @( t8 ~使用BP算法进行神经网络的训练。通过迭代调整权值和阈值来减小实际输出与期望输出之间的误差。迭代过程中,计算隐含层的输出HiddenOut和输出层的输出NetworkOut,计算误差Error,计算能量函数(误差平方和)SSE,并将其保存在ErrHistory中。如果误差小于目标误差E0,则跳出学习循环。核心的BP算法部分涉及到误差的反向传播和权值、阈值的调整。; ^: s9 o# y8 X( ?5 r5 i' m

. i! @) ]  u" z/ |4 V  P. Z9 W+ q2 o: m. \0 H
HiddenOut=logsig(W1*SamIn+repmat(B1,1,TestSamNum)); % 隐含层输出最终结果
! z5 C7 n5 Y0 xNetworkOut=W2*HiddenOut+repmat(B2,1,TestSamNum);    % 输出层输出最终结果3 U2 @/ f2 H# Z/ z
a=postmnmx(NetworkOut,mint,maxt);               % 还原网络输出层的结果
) m' l3 U0 n2 \9 s- z/ }& \2 Nx=1990:2009;                                        % 时间轴刻度
/ y: M# t& r1 i' R/ z! W1 c5 znewk=a(1,;                                        % 网络输出客运量
- D4 [8 @9 V1 T1 H, {newh=a(2,;                                        % 网络输出货运量
& [8 B6 Y5 P  G1 Q  ?8 P: _& }! t* bfigure ;8 @4 b0 R% T; C( H4 ~9 B: ^9 E
subplot(2,1,1);plot(x,newk,'r-o',x,glkyl,'b--+')    %绘值公路客运量对比图;( j0 X5 ]0 o0 k1 }
legend('网络输出客运量','实际客运量');+ I8 ?. H/ W  z: c/ a) a
xlabel('年份');ylabel('客运量/万人');; Y6 H1 m& b+ Z& u& p, s+ @
subplot(2,1,2);plot(x,newh,'r-o',x,glhyl,'b--+')     %绘制公路货运量对比图;, {( G. ^) u% h% F. o) |
legend('网络输出货运量','实际货运量');5 P' G4 V9 `; E' q9 h, b" _* v. j% H  v
xlabel('年份');ylabel('货运量/万吨');8 {, u2 N) j7 A4 f+ `9 t5 h; i+ F
使用训练好的神经网络对测试样本进行预测并还原归一化结果。将还原后的网络输出结果与实际数据绘制成图形进行对比展示% z) V7 |/ ?8 ~, b% ?1 M: p
; @7 G! T4 {; j# H9 N; U% l
pnew=[73.39 75.55$ T# Y, M, y5 x5 o
      3.9635 4.0975& C  M( T/ q% i9 @
      0.9880 1.0268];                     %2010年和2011年的相关数据;
8 o9 ^* `: D% P  J. y* I& T4 Npnewn=tramnmx(pnew,minp,maxp);         %利用原始输入数据的归一化参数对新数据进行归一化;9 o. k0 I$ T4 k
HiddenOut=logsig(W1*pnewn+repmat(B1,1,ForcastSamNum)); % 隐含层输出预测结果! k% G+ i  y  _3 K; o$ B3 h
anewn=W2*HiddenOut+repmat(B2,1,ForcastSamNum);           % 输出层输出预测结果
" Y  p# X! y9 M1 h%把网络预测得到的数据还原为原始的数量级;; o8 ]+ A+ f( G9 k
anew=postmnmx(anewn,mint,maxt);1 Y- l: E% Z7 _# F0 P
5 c9 M: x- B4 b, z& T5 t
给出了新的输入数据pnew,对其进行归一化处理得到归一化后的输入数据pnewn。然后,使用训练好的神经网络对归一化后的输入数据进行预测,得到归一化后的预测结果。最后,利用逆归一化操作将预测结果恢复为原始的数量级。) B& Y: O2 S% k; y* m7 A
该段代码主要包括数据预处理、神经网络的训练和预测,以及结果的可视化展示。通过训练得到的神经网络,可以对输入数据进行预测并输出相应的结果。( [' z: R! a" ]$ p) N/ f5 k
+ w$ d4 H9 z8 F, i2 i
对于代码将以附件形式给出
3 V; d8 ~7 ^) A2 r2 y$ u* g* \
7 w( Y- u# G& A0 Z% @
& H/ j4 i$ G  {3 }2 k' V( b3 ]; b  v. ]. e' a& p) c+ c* }! v" e8 w

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-4-15 05:05 , Processed in 0.439065 second(s), 55 queries .

回顶部