用matlab编BP神经网络预测程序.doc
《用matlab编BP神经网络预测程序.doc》由会员分享,可在线阅读,更多相关《用matlab编BP神经网络预测程序.doc(18页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、【精品文档】如有侵权,请联系网站删除,仅供学习与交流用matlab编BP神经网络预测程序.精品文档.求用matlab编BP神经网络预测程序求一用matlab编的程序 P=。;输入T=。;输出% 创建一个新的前向神经网络 net_1=newff(minmax(P),10,1,tansig,purelin,traingdm)% 当前输入层权值和阈值inputWeights=net_1.IW1,1inputbias=net_1.b1% 当前网络层权值和阈值layerWeights=net_1.LW2,1layerbias=net_1.b2% 设置训练参数net_1.trainParam.show =
2、 50;net_1.trainParam.lr = 0.05;net_1.trainParam.mc = 0.9;net_1.trainParam.epochs = 10000;net_1.trainParam.goal = 1e-3;% 调用 TRAINGDM 算法训练 BP 网络net_1,tr=train(net_1,P,T);% 对 BP 网络进行仿真A = sim(net_1,P);% 计算仿真误差 E = T - A;MSE=mse(E)x=。;%测试sim(net_1,x) 不可能啊 我2009 28对初学神经网络者的小提示第二步:掌握如下算法:2.最小均方误差,这个原理是下面提
3、到的神经网络学习算法的理论核心,入门者要先看高等数学(高等教育出版社,同济大学版)第8章的第十节:“最小二乘法”。3.在第2步的基础上看Hebb学习算法、SOM和K-近邻算法,上述算法都是在最小均方误差基础上的改进算法,参考书籍是神经网络原理(机械工业出版社,Simon Haykin著,中英文都有)、人工神经网络与模拟进化计算(清华大学出版社,阎平凡,张长水著)、模式分类(机械工业出版社,Richard O. Duda等著,中英文都有)、神经网络设计(机械工业出版社,Martin T. Hargan等著,中英文都有)。4.ART(自适应谐振理论),该算法的最通俗易懂的读物就是神经网络设计(机械
4、工业出版社,Martin T. Hargan等著,中英文都有)的第15和16章。若看理论分析较费劲可直接编程实现一下16.2.7节的ART1算法小节中的算法.4.BP算法,初学者若对误差反传的分析过程理解吃力可先跳过理论分析和证明的内容,直接利用最后的学习规则编个小程序并测试,建议看机器学习(机械工业出版社,Tom M. Mitchell著,中英文都有)的第4章和神经网络设计(机械工业出版社,Martin T. Hargan等著,中英文都有)的第11章。BP神经网络Matlab实例(1)分类:Matlab实例采用Matlab工具箱函数建立神经网络,对一些基本的神经网络参数进行了说明,深入了解参
5、考Matlab帮助文档。% 例1 采用动量梯度下降算法训练 BP 网络。 % 训练样本定义如下: % 输入矢量为 % p =-1 -2 3 1 % -1 1 5 -3 % 目标矢量为 t = -1 -1 1 1 close all clear clc % -% NEWFF生成一个新的前向神经网络,函数格式:% net = newff(PR,S1 S2.SNl,TF1 TF2.TFNl,BTF,BLF,PF) takes,% PR - R x 2 matrix of min and max values for R input elements% (对于R维输入,PR是一个R x 2 的矩阵,每
6、一行是相应输入的边界值)% Si - 第i层的维数% TFi - 第i层的传递函数, default = tansig% BTF - 反向传播网络的训练函数, default = traingdx% BLF - 反向传播网络的权值/阈值学习函数, default = learngdm% PF - 性能函数, default = mse% -% TRAIN对 BP 神经网络进行训练,函数格式:% train(NET,P,T,Pi,Ai,VV,TV),输入参数:% net - 所建立的网络% P - 网络的输入% T - 网络的目标值, default = zeros% Pi - 初始输入延迟,
7、default = zeros% Ai - 初始网络层延迟, default = zeros% VV - 验证向量的结构, default = % TV - 测试向量的结构, default = % 返回值:% net - 训练之后的网络% TR - 训练记录(训练次数及每次训练的误差)% Y - 网络输出% E - 网络误差% Pf - 最终输入延迟% Af - 最终网络层延迟% -% SIM对 BP 神经网络进行仿真,函数格式:% Y,Pf,Af,E,perf = sim(net,P,PiAi,T)% 参数与前同。% -% % 定义训练样本 % P 为输入矢量 echo onP=-1, -
8、2, 3, 1; -1, 1, 5, -3; % T 为目标矢量 T=-1, -1, 1, 1; % 创建一个新的前向神经网络 net=newff(minmax(P),3,1,tansig,purelin,traingdm) % -% 训练函数:traingdm,功能:以动量BP算法修正神经网络的权值和阈值。% 它的相关特性包括:% epochs:训练的次数,默认:100% goal:误差性能目标值,默认:0% lr:学习率,默认:0.01% max_fail:确认样本进行仿真时,最大的失败次数,默认:5% mc:动量因子,默认:0.9% min_grad:最小梯度值,默认:1e-10% sh
9、ow:显示的间隔次数,默认:25% time:训练的最长时间,默认:inf% -% 当前输入层权值和阈值 inputWeights=net.IW1,1 inputbias=net.b1 % 当前网络层权值和阈值 layerWeights=net.LW2,1 layerbias=net.b2 % 设置网络的训练参数 net.trainParam.show = 50; net.trainParam.lr = 0.05; net.trainParam.mc = 0.9; net.trainParam.epochs = 1000; net.trainParam.goal = 1e-3; % 调用 TR
10、AINGDM 算法训练 BP 网络 net,tr=train(net,P,T); % 对 BP 网络进行仿真 A = sim(net,P) % 计算仿真误差 E = T - A MSE=mse(E) echo offfigure;plot(1:4),T,-*,(1:4),A,-o)1 B P神经网络的原理及算法的基本步骤理 论上已证 明 ,一个 3层的 B P网络能够实现任意的连续映射 ,可以任意 精度逼近任何给定的连续函数 。1. 1B P神经网络的原理B P (B ack P rop aga tion)神经网络通常由具有多个节点的 输入层 ( inp u t laye r) 、隐含层 (
11、h idden laye r) 和多个 或一个输 出节点的输出层 ( ou tp u t laye r)组成 ,其学习过程分为信息的 正向传播过程和误差的反向传播过程两个阶段 。外部输入 的信号经输入层 、隐含层为止 。的神经元逐层处理 ,向前传播到输 出层 ,给出结果 。如果在输出层得不到期望输出 ,则转入逆 向传播过程 ,将实际值与网络输出之间的误差沿原连接通路 返回 ,通过修改各层神经元的连接权重 ,减少误差 ,然后再转 入正向传播过程 ,反复迭代 ,直到误差小于给定的值表1 19812005年全国总人口(单位:万人)年份198119821983198419851986198719881
12、989人口99622101541102495103604104639106008108000109614111191年份199019911992199319941995199619971998人口114333115823117171118517119850121121122389123626124810年份1999200020012002200320042005人口125909缺省127627128453129227129988130756模型二预测2001年2010年全国总人口(单位:万人)年份20012002200320042005人口127699128457129220129987130
13、758年份20062007200820092010人口131534132315133100133890134685 模型预测的全国总人口(1981年至2016年)(单位:万人)年份198119821983198419851991人口99266101308102967104600106203115172年份199219931994199520012002人口116550117895119205120480127403128436年份200320042005200620072008人口129437130405131340132244133116133958年份2009201020152020202
14、52030人口134770135552139049141921144257146144年份203520402045205020602070人口147659148869149832150596151678152352年份208020902100210521102120人口152769153026153185153240153283153344模型四预测2011至2020年人口(单位:万人)年份20112012201320142015全国总人口134668135478136325137185138036年份20162017201820192020全国总人口138862139652140402141
15、1061417602.1利用Matlab Script节点实现在此以对一个非线性函数的逼近作为例子来说明实现流程,其中输入矢量p=-10.051;目标矢量t=sin(2*pi*p)+0.1randn(size(p)。利用Mat-lab Script节点实现BP算法的过程如下:(1)新建一个LabVIEW vi,在框图程序中添加Matlab Script节点。(2)在节点内添加Matlab的动量BP算法实现代码,并分别在节点左右边框分别添加对应的输入/输出参数,如图1所示。(3)在vi的前面板添加相应的控件,设置输入参数,连接输出控件。执行程序,结果如图2、图3所示。下面的代码将重建我们以前的网
16、络,然后用批处理最速下降法训练网络。(注意用批处 理方式训练的话所有的输入要设置为矩阵方式)net=newff(-1 2; 0 5,3,1,tansig,purelin,traingd);net.trainParam.show = 50; net.trainParam.lr = 0.05; net.trainParam.epochs = 300; net.trainParam.goal = 1e-5;p = -1 -1 2 2;0 5 0 5; t = -1 -1 1 1; net=train(net,p,t);TRAINGD, Epoch 0/300, MSE 1.59423/1e-05,
17、Gradient 2.76799/1e-10TRAINGD, Epoch 50/300, MSE 0.00236382/1e-05, Gradient0.0495292/1e-10TRAINGD, Epoch 100/300, MSE 0.000435947/1e-05, Gradient0.0161202/1e-10TRAINGD, Epoch 150/300, MSE 8.68462e-05/1e-05, Gradient0.00769588/1e-10TRAINGD, Epoch 200/300, MSE 1.45042e-05/1e-05, Gradient0.00325667/1e-
18、10TRAINGD, Epoch 211/300, MSE 9.64816e-06/1e-05, Gradient0.00266775/1e-10TRAINGD, Performance goal met. a = sim(net,p)a =-1.0010 -0.9989 1.0018 0.9985用nnd12sd1 来演示批处理最速下降法的性能。 带动量的批处理梯度下降法(TRAINGDM)net=newff(-1 2; 0 5,3,1,tansig,purelin,traingdm);net.trainParam.show = 50; net.trainParam.lr = 0.05; n
19、et.trainParam.mc = 0.9; net.trainParam.epochs = 300; net.trainParam.goal = 1e-5;p = -1 -1 2 2;0 5 0 5; t = -1 -1 1 1; net=train(net,p,t);TRAINGDM, Epoch 0/300, MSE 3.6913/1e-05, Gradient 4.54729/1e-10TRAINGDM, Epoch 50/300, MSE 0.00532188/1e-05, Gradient0.213222/1e-10TRAINGDM, Epoch 100/300, MSE 6.3
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- matlab BP 神经网络 预测 程序
限制150内