欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    2022年BP神经网络的matlab实现学习历程.pdf

    • 资源ID:12786252       资源大小:674.35KB        全文页数:21页
    • 资源格式: PDF        下载积分:4.3金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要4.3金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    2022年BP神经网络的matlab实现学习历程.pdf

    考拉 BP神经网络的matlab 实现学习历程(一)考拉 BP神经网络的matlab 实现学习历程(一)本文考拉 BP神经网络的matlab 实现学习历程 系列由论坛 超级版主akjuan 整理和原创,我们在此表示特别感谢这两天在学习bp,总结和汇报一下,和大家一起学习。希望初入神经网络能有所收获,给新手一些帮组和启发。也希望熟悉bp 的高手,多提宝贵意见和建议。学习内容总结成五个小节,具体内容如下:第一节内容: 包括神经网络的基础知识,BP网络的特点,bp 主要应用的场合,使用时应注意的问题。第二节内容: 主要是阐述BP中几个容易混绕的概念和问题,包括什么是网络的泛化能力过拟合是什么,怎么处理学习速率有什么作用神经网络的权值和阈值分别是个什么概念用BP逼近非线性函数,如何提高训练精度?第三节内容: 主要阐述使用matlab 实现,为了充分利用数据,得到最优的网络训练结果,在网络建立前, 应该进行的基本数据处理问题,包括:BP神经网络matlab 实现的基本步骤,数据归一化问题和方法,输入训练数据的乱序排法,以及分类方法, 如何查看和保存训练的结果,每次结果不一样问题。第四节内容: bp 神经网络进行交通预测的Matlab 例子及源代码, bp 神经网络进行交通预测的 Matlab 程序的优化(主要是按设置误差要求,寻找最优网络过程)第五节内容: bp 神经网络处理蠓虫分类问题的matlab 例子及源代码。不多说,先如主题,第一节,很基础,高手见谅。什么是神经网络?神经网络是由很多神经元组成的,首先我们看一下,什么是神经元上面这个图表示的就是一个神经元,我们不管其它书上说的那些什么树突,轴突的。 我用个比较粗浅的解释,可能不太全面科学,但对初学者很容易理解:1、我们把输入信号看成你在matlab 中需要输入的数据,输进去神经网络后2、这些数据的每一个都会被乘个数,即权值w,然后这些东东与阀值b 相加后求和得到u,3、上面只是线性变化,为了达到能处理非线性的目的,u 做了个变换,变换的规则和传输函数有关精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 1 页,共 21 页 - - - - - - - - - - 可能还有人问, 那么那个阀值是什么呢简单理解就是让这些数据做了个平移,这就是神经元工作的过程。处理后的结果又作为输入,可输给别的神经元,很多这样的神经元,就组成了网络。 在 matlab 中具体用什么算法实现这些,我们先不管,我们需要注意的是怎么使用。比如使用 BP的神经网络newff()构建一个网络,这些在后面的学习将提到。BP网络的特点网络实质上实现了一个从输入到输出的映射功能,而数学理论已证明它具有实现任何复杂非线性映射的功能。这使得它特别适合于求解内部机制复杂的问题。我们无需建立模型,或了解其内部过程,只需输入,获得输出。只要 BPNN结构优秀, 一般 20 个输入函数以下的问题都能在 50000 次的学习以内收敛到最低误差附近。而且理论上, 一个三层的神经网络,能够以任意精度逼近给定的函数,这是非常诱人的期望;网络能通过学习带正确答案的实例集自动提取“合理的”求解规则,即具有自学习能力;网络具有一定的推广、概括能力。bp 主要应用回归预测 (可以进行拟合,数据处理分析,事物预测,控制等)、分类识别 (进行类型划分,模式识别等),在后面的学习中,我都将给出实例程序。但无论那种网络,什么方法,解决问题的精确度都无法打到100% 的,但并不影响其使用,因为现实中很多复杂的问题,精确的解释是毫无意义的,有意义的解析必定会损失精度。BP注意问题1、BP算法的学习速度很慢,其原因主要有:a 由于 BP算法本质上为梯度下降法,而它所要优化的目标函数又非常复杂,因此,必然会出现“锯齿形现象”,这使得BP算法低效;b 存在麻痹现象, 由于优化的目标函数很复杂,它必然会在神经元输出接近0 或 1 的情况下,出现一些平坦区,在这些区域内,权值误差改变很小,使训练过程几乎停顿;c 为了使网络执行BP算法,不能用传统的一维搜索法求每次迭代的步长,而必须把步长的更新规则预先赋予网络,这种方法将引起算法低效。2、网络训练失败的可能性较大,其原因有:a 从数学角度看,BP算法为一种局部搜索的优化方法,但它要解决的问题为求解复杂非线性函数的全局极值,因此,算法很有可能陷入局部极值,使训练失败;b 网络的逼近、 推广能力同学习样本的典型性密切相关,而从问题中选取典型样本实例组成训练集是一个很困难的问题。3、网络结构的选择:尚无一种统一而完整的理论指导,一般只能由经验选定。为此, 有人称神经网络的结构选择为一种艺术。 而网络的结构直接影响网络的逼近能力及推广性质。因此, 应用中如何选择合精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 2 页,共 21 页 - - - - - - - - - - 适的网络结构是一个重要的问题。4、新加入的样本要影响已学习成功的网络,而且刻画每个输入样本的特征的数目也必须相同。5、采用 s 型激活函数, 由于输出层各神经元的理想输出值只能接近于1 或 0,而不能打到1或 0,因此设置各训练样本的期望输出分量Tkp 时,不能设置为1 或 0,设置或较为适宜。考拉 BP神经网络的 matlab 实现学习历程(二)本文考拉 BP神经网络的matlab 实现学习历程 系列由论坛 超级版主akjuan 整理和原创,我们在此表示特别感谢本节主要学习BP中几个容易混绕的概念和问题:什么是网络的泛化能力过拟合是什么,怎么处理学习速率有什么作用神经网络的权值和阈值分别是个什么概念用BP逼近非线性函数,如何提高训练精度?什么是网络的泛化能力?一个神经网路是否优良, 与传统最小二乘之类的拟合评价不同(主要依据残差, 拟合优度等 ) ,不是体现在其对已有的数据拟合能力上,而是对后来的预测能力,既泛化能力。网络的预测能力(也称泛化能力、推广能力)与训练能力(也称逼近能力、学习能力)的矛盾。一般情况下,训练能力差时,预测能力也差,并且一定程度上,随训练能力地提高,预测能力也提高。 但这种趋势有一个极限,当达到此极限时,随训练能力的提高,预测能力反而下降,即出现所谓“过拟合”现象。此时,网络学习了过多的样本细节,而不能反映样本内含的规律。过拟合是什么,怎么处理?神经网络计算不能一味地追求训练误差最小,这样很容易出现“过拟合”现象,只要能够实时检测误差率的变化就可以确定最佳的训练次数,比如 15000 次左右的学习次数,如果你不观察,设成500000 次学习,不仅需要很长时间来跑,而且最后结果肯定令人大失所望。避免过拟合的一种方法是:在数据输入中, 给训练的数据分类,分为正常训练用、 变量数据、测试数据,在后面节将讲到如何进行这种分类。其中变量数据,在网络训练中,起到的作用就是防止过拟合状态。学习速率有什么作用?学习速率这个参数可以控制能量函数的步幅,并且如果设为自动调整的话,可以在误差率经过快速下降后,将学习速率变慢,从而增加BPNN 的稳定性。此时训练方法采用精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 3 页,共 21 页 - - - - - - - - - - 复制内容到剪贴板代码 :DE = traingda; % 变学习率梯度下降算法 = traingdx; % 变学习率动量梯度下降算法DE可以定义一个变动的学习速率,如复制内容到剪贴板代码 :DEp = -1 -1 2 2; 0 5 0 5; t = -1 -1 1 1; net = newff(p,t,3,traingda); = ; = ; net = train(net,p,t); y = sim(net,p)DE在后面的拟合例题中,我们也将用到学习速率这个参数。神经网络的权值和阈值分别是个什么概念?第一节中, 我们已经谈到了权值和阀值的概念。这里我们更深入的说明一下,因为他们很重要,关系到网络最后的结果。权值和阈值是神经元之间的连接,将数据输入计算出一个输出,然后与实际输出比较,误差反传,不断调整权值和阈值。假如下面两个点属于不同的类,须设计分类器将他们分开引用 :p1=1 1 -1; p2=1 -1 -1;这里用单层神经元感知器,假设初始权值复制内容到剪贴板代码 :DEw= DE同时假设初始阀值复制内容到剪贴板代码 :DEb=输出 a1 a2精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 4 页,共 21 页 - - - - - - - - - - 复制内容到剪贴板代码 :DEa1=hardlims(w*p1+b) a2=hardlims(w*p2+b)DE如果不能分开,还须不断调整w,b 用 BP逼近非线性函数,如何提高训练精度(1) 调整网络结构增加网络的层数可以进一步降低误差,提高精度但会使网络复杂化,从而增加网络的训练时间。 精度的提高实际上也可以通过增加隐层神经元的数目来获得,其效果更容易观察和掌握,所以应优先考虑。(2) 初始值选取为了使误差尽可能小,需要合理选择初始权重和偏置,如果太大就容易陷入饱和区,导致停顿。一般应选为均匀分布的小数,介于 (-1 ,1) 。(3) 学习速率调整学习速率的选取很重要,大了可能导致系统不稳定,小了会导致训练周期过长、收敛慢,达不到要求的误差。一般倾向于选取较小的学习速率以保持系统稳定,通过观察误差下降曲线来判断。 下降较快说明学习率比较合适,若有较大振荡则说明学习率偏大。同时,由于网络规模大小的不同,学习率选择应当针对其进行调整。采用变学习速率的方案,令学习速率随学习进展而逐步减少,可收到良好的效果。(4) 期望误差期望误差当然希望越小越好,但是也要有合适值。考拉 BP神经网络的 matlab 实现学习历程(三)本文考拉 BP神经网络的matlab 实现学习历程 系列由论坛 超级版主akjuan 整理和原创,我们在此表示特别感谢本节主要学习使用matlab 实现 bp 算法的一般步骤和过程。为了充分利用数据, 得到最优的网络训练结果,在网络建立前应该进行的基本数据处理问题,包括:(1)BP 神经网络 matlab 实现的基本步骤(2) 数据归一化问题和方法(3) 输入训练数据的乱序排法,以及分类方法(4) 如何查看和保存训练的结果(5) 每次结果不一样问题。精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 5 页,共 21 页 - - - - - - - - - - 用 matlab 实现 bp,其实很简单,按下面步骤基本可以了BP神经网络matlab 实现的基本步骤1、数据归一化2、数据分类,主要包括打乱数据顺序,抽取正常训练用数据、变量数据、测试数据3、建立神经网络,包括设置多少层网络(一般3 层以内既可以,每层的节点数(具体节点数,尚无科学的模型和公式方法确定,可采用试凑法, 但输出层的节点数应和需要输出的量个数相等) ,设置隐含层的传输函数等。关于网络具体建立使用方法,在后几节的例子中将会说到。4、指定训练参数进行训练,这步非常重要,在例子中,将详细进行说明5、完成训练后,就可以调用训练结果,输入测试数据,进行测试6、数据进行反归一化7、误差分析、结果预测或分类,作图等数据归一化问题归一化的意义:首先说一下,在工程应用领域中,应用BP网络的好坏最关键的仍然是输入特征选择和训练样本集的准备,若样本集代表性差、矛盾样本多、数据归一化存在问题,那么,使用多复杂的综合算法、 多精致的网络结构,建立起来的模型预测效果不会多好。若想取得实际有价值的应用效果,从最基础的数据整理工作做起吧,会少走弯路的。归一化是为了加快训练网络的收敛性,具体做法是:1 把数变为( 0,1)之间的小数主要是为了数据处理方便提出来的,把数据映射到0 1 范围之内处理,更加便捷快速,应该归到数字信号处理范畴之内。2 把有量纲表达式变为无量纲表达式归一化是一种简化计算的方式,即将有量纲的表达式,经过变换,化为无量纲的表达式,成为纯量比如,复数阻抗可以归一化书写:Z = R + jL = R(1 + jL/R) ,复数部分变成了纯数量了,没有量纲。另外,微波之中也就是电路分析、信号系统、电磁波传输等,有很多运算都可以如此处理,既保证了运算的便捷,又能凸现出物理量的本质含义。神经网络归一化方法:由于采集的各数据单位不一致,因而须对数据进行-1,1归一化处理, 归一化方法主要有如下几种,供大家参考:1、线性函数转换,表达式如下:复制内容到剪贴板精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 6 页,共 21 页 - - - - - - - - - - 代码 :DEy=(x-MinValue)/(MaxValue-MinValue)DE说明: x、y 分别为转换前、后的值,MaxValue、MinValue 分别为样本的最大值和最小值。2、对数函数转换,表达式如下:复制内容到剪贴板代码 :DEy=log10(x)DE说明:以 10 为底的对数函数转换。3、反余切函数转换,表达式如下:复制内容到剪贴板代码 :DEy=atan(x)*2/PIDEmatlab 中归一化的实现:matlab 中的归一化处理有五种方法,只会其中一种就可以了,我喜欢用第4种,因为习惯和方便注意:第一组和第二组归一化函数在以上已遗弃,他们的用法相似, pre* 是归一化, post*是反归一化, tram* 是使用同样的设置归一化另外一组数据1. 内部函数 premnmx 、postmnmx、tramnmx,将数据归一化到(-1,1) premnmx的语法格式是复制内容到剪贴板代码 :DE :Pn,minp,maxp,Tn,mint,maxt=premnmx(P,T)DE其中 P,T分别为原始输入和输出数据,minp 和 maxp分别为 P中的最小值和最大值。mint和 maxt 分别为 T 的最小值和最大值。我们在训练网络时,如果所用的是经过归一化的样本数据,那么以后使用网络时所用的新数据也应该和样本数据接受相同的预处理,这就要用到tramnmx,换句话说使用同一个归一化设置 (setting)归一化另外一组数据。如下所示:复制内容到剪贴板代码 :DEPn=tramnmx(P,minp,maxp)DE其中 P和 Pn分别为变换前、后的输入数据,maxp和 minp 分别为 premnmx函返回的最大值maxp和最小值 minp。精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 7 页,共 21 页 - - - - - - - - - - 2、prestd 、poststd 、trastd归化数据到 (0,1) 用法与 1 差不多。详细可以help prestd。上述两种方法是可以相互转化的,比如, 第一种归化后的数据为p,则(1+p)./2的结果就是第二种了3、mapminmax()将数据归一化到(-1,1),是中 *mnmx系列的替换函数该函数同时可以执行归一化、反归一化和归一化其他数据的功能,具体看帮助和后面的实例复制内容到剪贴板代码 :DE% 归一化数据输入为p,输出为t normInput,ps = mapminmax(p); normTarget,ts = mapminmax(t); % 反归一化trainOutput = mapminmax(reverse,normTrainOutput,ts); trainInsect = mapminmax(reverse,ts); validateOutput = mapminmax(reverse,normValidateOutput,ts); validateInsect = mapminmax(reverse,ts); testOutput = mapminmax(reverse,normTestOutput,ts); testInsect = mapminmax(reverse,ts); % 例子:x1 = 1 2 4; 1 1 1; 3 2 2; 0 0 0 y1,PS = mapminmax(x1,0,1)% 归化到 0,1,若不填,则默认为-1,1 % 还原:x1_again = mapminmax(reverse,y1,PS)DE4、mapstd() 将数据归一化到(0,1),是中 *std系列的替代函数同理, 3 和 4 两种方法是可以相互转化的,比如,第一种归化后的数据为p,则 (1+p)./2的结果就是第二种了。5、自己写归一化函数,这个网上很多,大家可以百度下输入训练数据的乱序排法,以及分类注意: dividevec()函数在版本还可以使用把数据重新打乱顺序,进行输入,可以让数据更加具备典型性和更优良的泛化能力!精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 8 页,共 21 页 - - - - - - - - - - 把数据进行打乱,并分类为:训练输入数据、变量数据、测试数据的方法我用百度搜了一下,发现有些方法,但居然很少看到使用matlab 内部函数直接进行的,其实 matlab 自带的内部函数dividevec,完全能胜任上述工作,推荐! 但这个存在一个问题是,因为打乱了,最后分析结果的时候,数据重新排列困难,因为丢失了数据在数组中的位置参数。具体用法可以参见下面我的bp 交通预测的例子。因为我用的版本,Neural Network Toolbox Version (R2007a)昨天,我去mathworks 公司查看了一下nnet 的新手册,上述问题得到了解决,里面视乎没有介绍 dividverc这个函数了, 但增加了新的函数来完成上述功能,并返回标号 (手头没装新版本 Neural Network Toolbox Version (R2008a) ),看 guide 大概是这个意思( 有新版本的,可以试一下,这个函数是不是这个意思) :divideblock,divideind,divideint和 dividerand上述函数, 用法和功能基本相同,只是打乱的方法不一样,分别是block方法抽取、按数组标号自定义抽取、交错索引抽取和随机抽。下面以 divideblock为例,讲解其基本用法:复制内容到剪贴板代码 :DEtrainV,valV,testV,trainInd,valInd,testInd =divideblock(allV,trainRatio,valRatio,testRatio) 训练数据 , 变量数据 , 测试数据 , 训练数据矩阵的标号, 变量数据标号 , 测试数据标号 =divideblock(所有数据 , 训练数据百分比, 变量数据百分比, 测试数据百分比)DE其实 dividevec和后面四个分类函数的区别在于,dividevec一般直接在Matlab 代码中调用。而后面四个函数是通过设置网络的divideFcn函数来实现, 比如, =divideblock,但不是说不可以在代码中像dividevec直接调用如何查看和保存结果训练好的权值、阈值的输出方法是:输入到隐层权值:复制内容到剪贴板代码 :DEw1=1,1DE精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 9 页,共 21 页 - - - - - - - - - - 隐层阈值:复制内容到剪贴板代码 :DEtheta1=1DE隐层到输出层权值:复制内容到剪贴板代码 :DEw2=2,1;DE输出层阈值:复制内容到剪贴板代码 :DEtheta2=2DE训练好的 BP神经网络保存:复制内容到剪贴板代码 :DE% 保存save file_name net_name%Matlab自动将网络保存为mat 数据文件,下次使用时可以直接载入% 载入load file_nameDE每次结果不一样问题因为每次初始化网络时都是随机的,而且训练终止时的误差也不完全相同,结果训练后的权植和阀也不完全相同(大致是一样的),所以每次训练后的结果也略有不同。找到比较好的结果后,用命令save filen_ame net_name 保存网络,可使预测的结果不会变化,在需要的调用时用命令load filename载入。关于如何找到比较好的结果,进行保存,可以设置误差, 在循环中保存,具体使用可以参看bp 交通预测优化后的例子考拉 BP神经网络的 matlab 实现学习历程(四) bp神经网络进行交通预测的Matlab 源代码本文考拉 BP神经网络的matlab 实现学习历程 系列由论坛 超级版主akjuan 整理和原创,我们在此表示特别感谢精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 10 页,共 21 页 - - - - - - - - - - 根据前面三节的学习内容,可以基本编写一个BP神经网络,来处理一些问题了。下面我给出一个bp 神经网络进行交通预测的Matlab 源代码, 里面备有较为详细的注释,供给初学者!复制内容到剪贴板代码 :DE%bp 神经网络进行交通预测的Matlab 源代码% BP 神经网络用于预测% 使用平台 - % 数据为 1986 年到 2000 年的交通量,网络为 3 输入, 1 输出% 15 组数据,其中9 组为正常训练数据,3 组为变量数据,3 组为测试数据%by akjuan %all rights preserved by % clc clear %- % 原始数据%- year=1986:2000;% 数据是从 1986 到 2000 年的p=493 372 445;372 445 176;445 176 235;176 235 378;235 378 429;. 378 429 561;429 561 651;561 651 467;651 467 527;467 527 668;. 527 668 841; 668 841 526;841 526 480;526 480 567;480 567 685;%输入数据,共15组,每组 3 个输入t=176 235 378 429 561 651 467 527 668 841 526 480 567 685 507;%输出数据,共15组,每组 1 个输出%- % 数据归一化处理%mapminmax 函数默认将数据归一化到-1,1,调用形式如下%y,ps =%mapminmax(x,ymin,ymax) %x需归化的数据输入%ymin ,ymax为需归化到的范围,不填默认为归化到-1,1 %y归一化后的样本数据%ps处理设置, ps 主要在结果反归一化中需要调用,或者使用同样的settings归一化另外一组数据%- normInput,ps = mapminmax(p); normTarget,ts = mapminmax(t); 精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 11 页,共 21 页 - - - - - - - - - - %- % 数据乱序,及分类处理% 将输入的 15 组数据的 20% ,即 3 组,用来作为测试数据;% 样本的 20% ,即 3组,用来作为变化数据;% 另外 9 组用来正常输入,用来训练;%dividevec()用来重新随机抽取上述三种分类的数据,原来的顺序被打乱% 函数调用的语法%trainV,valV,testV = dividevec(p,t,valPercent,testPercent) % 输入 p 为输入数据, t 为输出数据%valPercent为训练用的变化数据在总输入中的百分比%testPercent为训练用的测试数据在总输入中的百分比% 输出 trainV,valV,testV分别为按乱序及相应百分比,抽取得到的数据% 另外,打乱后的数据,p 和 t 都是对应的,请放心使用%- testPercent = ; % Adjust as desired validatePercent = ; % Adust as desired trainSamples,validateSamples,testSamples = dividevec(normInput,normTarget,validatePercent,testPercent); %- % 设置网络参数%- NodeNum1 = 20; % 隐层第一层节点数NodeNum2=40; % 隐层第二层节点数TypeNum = 1; % 输出维数TF1 = tansig;TF2 = tansig; TF3 = tansig;%各层传输函数,TF3 为输出层传输函数% 如果训练结果不理想,可以尝试更改传输函数,以下这些是各类传输函数%TF1 = tansig;TF2 = logsig; %TF1 = logsig;TF2 = purelin; %TF1 = tansig;TF2 = tansig; %TF1 = logsig;TF2 = logsig; %TF1 = purelin;TF2 = purelin; % 注意创建 BP网络函数 newff()的参数调用,在新版本中已改变net=newff(minmax(normInput),NodeNum1,NodeNum2,TypeNum,TF1 TF2 TF3,traingdx);%创建四层BP网络精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 12 页,共 21 页 - - - - - - - - - - %- % 设置训练参数%- 训练次数设置训练目标设置学习率设置 , 应设置为较少值,太大虽然会在开始加快收敛速度,但临近最佳点时,会产生动荡,而致使无法收敛%- % 指定训练函数%- % = traingd; % 梯度下降算法% = traingdm; % 动量梯度下降算法% % = traingda; % 变学习率梯度下降算法% = traingdx; % 变学习率动量梯度下降算法% % (大型网络的首选算法) % = trainrp; % RPROP(弹性 BP)算法 , 内存需求最小% % (共轭梯度算法 ) % = traincgf; % Fletcher-Reeves修正算法% = traincgp; % Polak-Ribiere修正算法 , 内存需求比Fletcher-Reeves修正算法略大% = traincgb; % Powell-Beal复位算法 , 内存需求比Polak-Ribiere修正算法略大% % (大型网络的首选算法) % = trainscg; % Scaled Conjugate Gradient算法 , 内存需求与Fletcher-Reeves修正算法相同 ,计算量比上面三种算法都小很多% = trainbfg; % Quasi-Newton Algorithms - BFGS Algorithm,计算量和内存需求均比共轭梯度算法大, 但收敛比较快% = trainoss; % One Step Secant Algorithm,计算量和内存需求均比BFGS 算法小 , 比共轭梯度算法略大% % (中型网络的首选算法) % = trainlm; % Levenberg-Marquardt算法 ,内存需求最大, 收敛速度最快% = trainbr; % 贝叶斯正则化算法% % 有代表性的五种算法为:traingdx,trainrp,trainscg,trainoss, trainlm =traingdm; net,tr = train(net,validateSamples,testSamples); %- % 训练完成后,就可以调用sim() 函数,进行仿真了%- 精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 13 页,共 21 页 - - - - - - - - - - normTrainOutput,Pf,Af,E,trainPerf = sim(net,;%正常输入的9 组 p 数据, BP得到的结果t normValidateOutput,Pf,Af,E,validatePerf = sim(net,;%用作变量3 的数据 p,BP得到的结果t normTestOutput,Pf,Af,E,testPerf = sim(net,;%用作测试的3 组数据 p,BP得到的结果 t %- % 仿真后结果数据反归一化,如果需要预测,只需将预测的数据P填入% 将获得预测结果t %- trainOutput = mapminmax(reverse,normTrainOutput,ts);%正常输入的9 组 p 数据, BP得到的归一化后的结果t trainInsect = mapminmax(reverse,ts);%正常输入的9 组数据 t validateOutput = mapminmax(reverse,normValidateOutput,ts);%用作变量3 的数据 p,BP得到的归一化的结果t validateInsect = mapminmax(reverse,ts);%用作变量3 的数据 t testOutput = mapminmax(reverse,normTestOutput,ts);%用作变量3 组数据 p,BP得到的归一化的结果t testInsect = mapminmax(reverse,ts);%用作变量3 组数据 t %- % 数据分析和绘图%- figure plot(1:12,trainOutput validateOutput,b-,1:12,trainInsect validateInsect,g-,13:15,testOutput,m*,13:15,testInsect,ro); title(o为真实值, *为预测值 ) xlabel(年份 ); ylabel(交通量(辆次 / 昼夜) );DE运行后的结果如下图,注意该程序是在版本上实验的,没法在版本运行,因为版本的归一化函数被遗弃了; 在以上版本没有没法运行,因为 newff 函数参数形式改变了。但是只要将上面提到部分相应修改下,就可以运行了正常数据,是用来正常训练用变量数据,主要目的是防止训练中出现过拟合状态精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 14 页,共 21 页 - - - - - - - - - - 测试数据,是用来看训练效果的考拉 BP神经网络的 matlab 实现学习历程(五) bp神经网络进行交通预测程序优化本文考拉 BP神经网络的matlab 实现学习历程 系列由论坛 超级版主akjuan 整理和原创,我们在此表示特别感谢在第四节,给出的BP网络进行交通预测的程序,是个基本模式,更改少数几处参数后,可用于其它方面!但通过程序运行后,可以看出, 预测效果并不理想,如何得到理想的预测训练结果,下面是基本思路及matlab 的实现:1、设置一个误差项,为测试数据的网络仿真结果和实际结果偏差,并设置一个自己能接受的精度值2、每次训练网络后,将这个误差和设置值比较,也可通过测试获得网络能给出的最高预测精度3、得到满意训练网络后,保存BP结果,以便下次调用下面这个程序是在第四节程序基础上优化而来,可以运行前面的程序和这个程序,比较两者的差别,可以通过修改eps 来控制预测的误差!复制内容到剪贴板代码 :DE%bp 神经网络进行交通预测的Matlab 源代码% BP 神经网络用于预测% 使用平台 - 精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 15 页,共 21 页 - - - - - - - - - - % 数据为 1986 年到 2000 年的交通量,网络为 3 输入, 1 输出% 15 组数据,其中9 组为正常训练数据,3 组为变量数据,3 组为测试数据%by akjuan %all rights preserved by % clc clear All_error=;%所有误差存储%- % 原始数据%- year=1986:2000;% 数据是从 1986 到 2000 年的p=493 372 445;372 445 176;445 176 235;176 235 378;235 378 429;. 378 429 561;429 561 651;561 651 467;651 467 527;467 527 668;. 527 668 841; 668 841 526;841 526 480;526 480 567;480 567 685;%输入数据,共15组,每组 3 个输入t=176 235 378 429 561 651 467 527 668 841 526 480 567 685 507;%输出数据,共15组,每组 1 个输出%- % 数据归一化处理%mapminmax 函数默认将数据归一化到-1,1,调用形式如下%y,ps =%mapminmax(x,ymin,ymax) %x需归化的数据输入%ymin ,ymax为需归化到的范围,不填默认为归化到-1,1 %y归一化后的样本数据%ps处理设置, ps 主要在结果反归一化中需要调用,或者使用同样的settings归一化另外一组数据%- normInput,ps = mapminmax(p); normTarget,ts = mapminmax(t); %- % 数据乱序,及分类处理% 将输入的 15 组数据的 20% ,即 3 组,用来作为测试数据;% 样本的 20% ,即 3组,用来作为变化数据;% 另外 9 组用来正常输入,用来训练;%dividevec()用来重新随机抽取上述三种分类的数据,原来的顺序被打乱精品资料 - - - 欢迎下载 - - - - - - - - - - - 欢迎下载 名师归纳 - - - - - - - - - -第 16 页,共 21 页 - - - - - - - - - - % 函数调用的语法%trainV,valV,testV = dividevec(p,t,valPercent,testPercent) % 输入 p 为输入数据, t 为输出数据%valPercent为训练用的变化数据在总输入中的百分比%testPercent为训练用的测试数据在总输入中的百分比% 输出 trainV,valV,testV分别为按乱序及相应百分比,抽取得到的数据% 另外,打乱后的数据,p 和 t 都是对应的,请放心使用%- testPercent = ; % Adjust as desired validatePercent = ; % Adust as desired trainSamples,validateSamples,testSamples = dividevec(normInput,normTarget,validatePercent,te

    注意事项

    本文(2022年BP神经网络的matlab实现学习历程.pdf)为本站会员(C****o)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开