BP神经网络的基本原理_一看就懂.pdf

上传人:ylj18****41534 文档编号:80893340 上传时间:2023-03-23 格式:PDF 页数:14 大小:728.52KB
返回 下载 相关 举报
BP神经网络的基本原理_一看就懂.pdf_第1页
第1页 / 共14页
BP神经网络的基本原理_一看就懂.pdf_第2页
第2页 / 共14页
点击查看更多>>
资源描述

《BP神经网络的基本原理_一看就懂.pdf》由会员分享,可在线阅读,更多相关《BP神经网络的基本原理_一看就懂.pdf(14页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、 .下载可编辑.5.4 BP 神经网络的基本原理 BP(Back Propagation)网络是 1986 年由 Rinehart 和McClelland 为首的科学家小组提出,是一种按误差逆传播算法训练的多层前馈网络,是目前应用最广泛的神经网络模型之一。BP 网络能学习和存贮大量的输入-输出模式映射关系,而无需事前揭示描述这种映射关系的数学方程。它的学习规则是使用最速下降法,通过反向传播来不断调整网络的权值和阈值,使网络的误差平方和最小。BP 神经网络模型拓扑结构包括输入层(input)、隐层(hide layer)和输出层(output layer)(如图 5.2 所示)。5.4.1 BP

2、 神经元 图 5.3 给出了第 j 个基本 BP 神经元(节点),它只模仿了生物神经元所具有的三个最基本也是最重要的功能:加权、求和与转移。其中 x1、x2xixn分别代表来自神经元 1、2in的输入;wj1、wj2wjiwjn则分别表示神经元 1、2in 与第 j 个神经元的连接强度,即权值;bj为阈值;f()为传递函数;yj为第 j 个神经元的输出。第 j 个神经元的净输入值为:(5.12)其中:.下载可编辑.若视,即令及包括及,则 于是节点 j 的净输入可表示为:(5.13)净输入通过传递函数(Transfer Function)f()后,便得到第 j 个神经元的输出:(5.14)式中

3、f()是单调上升函数,而且必须是有界函数,因为细胞传递的信号不可能无限增加,必有一最大值。5.4.2 BP 网络 BP 算法由数据流的前向计算(正向传播)和误差信号的反向传播两个过程构成。正向传播时,传播方向为输入层隐层输出层,每层神经元的状态只影响下一层神经元。若在输出层得不到期望的输出,则转向误差信号的反向传播流程。通过这两个过程的交替进行,在权向量空间执行误差函数梯度下降策略,动态迭代搜索一组权向量,使网络误差函数达到最小值,从而完成信息提取和记忆过程。5.4.2.1 正向传播 .下载可编辑.设 BP 网络的输入层有 n 个节点,隐层有 q 个节点,输出层有 m 个节点,输入层与隐层之间

4、的权值为,隐层与输出层之间的权值为,如图 5.4 所示。隐层的传递函数为 f1(),输出层的传递函数为 f2(),则隐层节点的输出为(将阈值写入求和项中):k=1,2,q (5.15)输出层节点的输出为:j=1,2,m (5.16)至此 B-P 网络就完成了 n 维空间向量对 m 维空间的近似映射。5.4.2.2 反向传播 1)定义误差函数 输入个学习样本,用来表示。第个样本输入到网络后得到输出(j=1,2,m)。采用平方型误差函数,于是得到第p个样本的误差Ep:(5.17)式中:为期望输出。对于个样本,全局误差为:.下载可编辑.(5.18)2)输出层权值的变化 采用累计误差 BP 算法调整,

5、使全局误差变小,即 (5.19)式中:学习率 定义误差信号为:(5.20)其中第一项:(5.21)第二项:(5.22)是输出层传递函数的偏微分。于是:(5.23)由链定理得:.下载可编辑.(5.24)于是输出层各神经元的权值调整公式为:(5.25)3)隐层权值的变化 (5.26)定义误差信号为:(5.27)其中第一项:(5.28)依链定理有:(5.29)第二项:(5.30)是隐层传递函数的偏微分。于是:.下载可编辑.(5.31)由链定理得:(5.32)从而得到隐层各神经元的权值调整公式为:(5.33)5.4.3 BP 算法的改进 BP 算法理论具有依据可靠、推导过程严谨、精度较高、通用性较好等

6、优点,但标准 BP 算法存在以下缺点:收敛速度缓慢;容易陷入局部极小值;难以确定隐层数和隐层节点个数。在实际应用中,BP 算法很难胜任,因此出现了很多改进算法。1)利用动量法改进 BP 算法 标准 BP 算法实质上是一种简单的最速下降静态寻优方法,在修正 W(K)时,只按照第 K 步的负梯度方向进行修正,而没有考虑到以前积累的经验,即以前时刻的梯度方向,从而常常使学习过程发生振荡,收敛缓慢。动量法权值调整算法的具体做法是:将上一次权值调整量的一部分迭加到按本次误差计算所得的权值调整量上,作为本次的实际权值调整量,即:(5.34)其中:为动量系数,通常 00.9;学习率,范围在 0.00110

7、之间。这种方法所加的动量因子实际上相当于阻尼项,它减小了学习过程中的振荡趋势,从而改善了收敛性。动量法降低了网络对于误差曲面局部细节的敏感性,有效的抑制了网络陷入局部极小。2)自适应调整学习速率 .下载可编辑.标准 BP 算法收敛速度缓慢的一个重要原因是学习率选择不当,学习率选得太小,收敛太慢;学习率选得太大,则有可能修正过头,导致振荡甚至发散。可采用图 5.5 所示的自适应方法调整学习率。调整的基本指导思想是:在学习收敛的情况下,增大,以缩短学习时间;当偏大致使不能收敛时,要及时减小,直到收敛为止。3)动量-自适应学习速率调整算法 采用动量法时,BP 算法可以找到更优的解;采用自适应学习速率

8、法时,BP 算法可以缩短训练时间。将以上两种方法结合起来,就得到动量-自适应学习速率调整算法。4)L-M 学习规则 L-M(Levenberg-Marquardt)算法比前述几种使用梯度下降法的 BP 算法要快得多,但对于复杂问题,这种方法需要相当大的存储空间。L-M(Levenberg-Marquardt)优化方法的权值调整率选为:(5.35)其中:e误差向量;J网络误差对权值导数的雅可比(Jacobian)矩阵;标量,当很大时上式接近于梯度法,当很小时上式变成了 Gauss-Newton 法,在这种方法中,也是自适应调整的。综合考虑,拟采用 L-M 学习规则和动量法分别作为神经网络的训练函

9、数和学习函数。5.5 BP 神经网络的训练策略及结果 本文借助于 MATLAB 神经网络工具箱来实现多层前馈 BP 网络(Multi-layer feed-forward backpropagation network)的颜色空间转换,免去了许多编写计算机程序的烦恼。神经网络的实际输出值与输入值以及各权值和阈值有关,为了使实际输出值与网络期望输出值相吻合,可用含有一定数量学习样本的样本集和相应期望输出值的集合来训练网络。训练时仍然使用本章 5.2 节中所述的实测样本数据。.下载可编辑.另外,目前尚未找到较好的网络构造方法。确定神经网络的结构和权系数来描述给定的映射或逼近一个未知的映射,只能通过

10、学习方式得到满足要求的网络模型。神经网络的学习可以理解为:对确定的网络结构,寻找一组满足要求的权系数,使给定的误差函数最小。设计多层前馈网络时,主要侧重试验、探讨多种模型方案,在实验中改进,直到选取一个满意方案为止,可按下列步骤进行:对任何实际问题先都只选用一个隐层;使用很少的隐层节点数;不断增加隐层节点数,直到获得满意性能为止;否则再采用两个隐层重复上述过程。训练过程实际上是根据目标值与网络输出值之间误差的大小反复调整权值和阈值,直到此误差达到预定值为止。5.5.1 确定 BP 网络的结构 确定了网络层数、每层节点数、传递函数、初始权系数、学习算法等也就确定了BP 网络。确定这些选项时有一定

11、的指导原则,但更多的是靠经验和试凑。1)隐层数的确定:1998 年 Robert Hecht-Nielson 证明了对任何在闭区间内的连续函数,都可以用一个隐层的BP 网络来逼近,因而一个三层的 BP 网络可以完成任意的 n 维到 m 维的映照。因此我们从含有一个隐层的网络开始进行训练。2)BP 网络常用传递函数:BP 网络的传递函数有多种。Log-sigmoid 型函数的输入值可取任意值,输出值在0 和 1 之间;tan-sigmod 型传递函数 tansig 的输入值可取任意值,输出值在-1 到+1 之间;线性传递函数 purelin 的输入与输出值可取任意值。BP 网络通常有一个或多个隐

12、层,该层中的神 .下载可编辑.经元均采用 sigmoid 型传递函数,输出层的神经元则采用线性传递函数,整个网络的输出可以取任意值。各种传递函数如图 5.6 所示。只改变传递函数而其余参数均固定,用本章 5.2 节所述的样本集训练 BP 网络时发现,传递函数使用 tansig 函数时要比 logsig 函数的误差小。于是在以后的训练中隐层传递函数改用 tansig 函数,输出层传递函数仍选用 purelin 函数。3)每层节点数的确定:使用神经网络的目的是实现摄像机输出 RGB 颜色空间与 CIE-XYZ 色空间转换,因此 BP 网络的输入层和输出层的节点个数分别为 3。下面主要介绍隐层节点数

13、量的确定。对于多层前馈网络来说,隐层节点数的确定是成败的关键。若数量太少,则网络所能获取的用以解决问题的信息太少;若数量太多,不仅增加训练时间,更重要的是隐层节点过多还可能出现所谓“过渡吻合”(Overfitting)问题,即测试误差增大导致泛化能力下降,因此合理选择隐层节点数非常重要。关于隐层数及其节点数的选择比较复杂,一般原则是:在能正确反映输入输出关系的基础上,应选用较少的隐层节点数,以使网络结构尽量简单。本论文中采用网络结构增长型方法,即先设置较少的节点数,对网络进行训练,并测试学习误差,然后逐渐增加节点数,直到学习误差不再有明显减少为止。5.5.2 误差的选取 在神经网络训练过程中选

14、择均方误差 MSE 较为合理,原因如下:标准 BP 算法中,误差定义为:(5.36)每个样本作用时,都对权矩阵进行了一次修改。由于每次权矩阵的修改都没有考虑权值修改后其它样本作用的输出误差是否也减小,因此将导致迭代次数增加。累计误差 BP 算法的全局误差定义为:(5.37).下载可编辑.这种算法是为了减小整个训练集的全局误差,而不针对某一特定样本,因此如果作某种修改能使全局误差减小,并不等于说每一个特定样本的误差也都能同时减小。它不能用来比较 P 和 m 不同的网络性能。因为对于同一网络来说,P 越大,E 也越大;P 值相同,m 越大E 也越大。均方误差 MSE:(5.38)其中:输出节点的个

15、数,训练样本数目,网络期望输出值,网络实际输出值。均方误差克服了上述两种算法的缺点,所以选用均方误差算法较合理。5.5.3 训练结果 训练一个单隐层的三层 BP 网络,根据如下经验公式选择隐层节点数125:(5.39)式中:n 为输入节点个数,m 为输出节点个数,a 为 1 到 10 之间的常数。针对本论文 n1取值范围为 313。训练结果如表 5.1 所示。表 5.1 隐层节点数与误差的关系 隐层神经元个数 训练误差 测试误差 3 1.25661 1.1275 4 0.797746 0.8232 5 0.631849 0.7278 6 0.570214 0.6707 7 0.552873 0

16、.6895 8 0.445118 0.6575 9 0.385578 0.6497 10 0.259624 0.4555 11 0.185749 0.6644 .下载可编辑.12 0.183878 0.48 13 0.168587 0.6671 由上表可以看出:增加隐层节点数可以减少训练误差,但超过 10 以后测试误差产生波动,即泛化能力发生变化。综合比较隐层节点数为 10 与 12 的训练误差和测试误差,决定隐层节点数选用 12。训练误差和测试误差都很大,而且收敛速度极慢(训练过程如图 5.7 所示),这个问题可以通过对输出量进行归一化来解决。根据 Sigmoid 型传递函数输入和输出的范围

17、,对输入变量不进行归一化处理,只对输出变量进行归一化,这是因为在输出数据要求归一化的同时,对输入数据也进行归一化的话,权值的可解释性就更差了。目标值按下式进行变化:(5.40)使目标值落在0.050.95之间,这样靠近数据变化区间端点的网络输出值就有一波动范围,网络的性能较好。用新生成的训练样本与测试样本对隐层节点数为 12 的网络进行训练,得到的训练误差为 9.8902810-5,测试误差为 1.989910-4,达到了预定的目标(训练过程如图 5.8 所示)。.下载可编辑.5.6 最终训练后的神经网络结构 采用三层 BP 网络实现摄像机输出 RGB 颜色空间与 CIEXYZ 色空间转换,其

18、中隐层含有 12 个节点,传递函数采用 tansig 函数;输出层传递函数选用 purelin 函数。经过测试后结果满意,可以认为该神经网络可以用来实现这个关系映射。网络的结构如图 5.9 所示:.下载可编辑.得到的 BP 神经网络的权值和阈值为:.下载可编辑.5.7 本章小结 1)定量地分析了用线性关系转换摄像机RGB空间到CIE-XYZ空间数据后产生的均方误差,表明 CCD 摄像机与标准观察者之间有比较明显的差别,也就是说 RGB 与 CIE-XYZ 间的转换是非线性的。2)采用 MATLAB 中神经网络工具箱实现多层前馈 BP 网络的 RGB 到 CIEXYZ颜色空间转换,用经过归一化的训练样本与测试样本对隐层节点数为 12 的三层网络进行训练,得到的训练误差为 9.8902810-5,测试误差为 1.989910-4,结果表明经过训练的多层前馈 BP网络可以满足 RGB 空间向 CIEXYZ 颜色空间转换要求,达到了预定目标。3)确定了用于 RGB 和 XYZ 颜色空间转换的 BP 网络结构,并求出了该神经网络的权值和阈值。使用该网络可以定量表达食品颜色,定量比较高压加工食品颜色的变化,可以使食品颜色测定和控制实现定量化,而不再是主观性很强的模糊描述。

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 应用文书 > 工作报告

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

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