神经网络预测编码器的设计及应用

时间:2009-06-19

  1 BP网络结构及其算法

  反向传播算法又称误差后向传播算法(Error Back Propagation Algorithm),它是用来训练多层前馈网络的一种学习算法。是一种有监督的学习算法。通常称用误差反向传播算法训练的网络叫BP网络。如图1所示,该BP网络具有一个输入层,两个隐含层(也称中间层)和一个输出层组成,各层之间实行全连接。BP神经网络的隐含层通常具有多个,其传输函数常常采用sigmoid函数,而输入输出层则采用线性传输函数。

  误差反向传播算法的主要思想是把学习过程分为两个阶段:阶段(正向传播过程),给出输入信息通过输入层经隐含层逐层处理并计算每个单元的实际输出值;第二阶段(反向传播过程),若在输出层未能得到期望的输出值,则逐层递归地计算实际输出与期望输出之差值(即误差),以便根据此误差调节权值。误差反向传播算法的性能函数是均方误差。其算法流程如图2所示。


  2 神经网络预测编码器的设计及应用

  2.1 预测器层数

  kolmogorov定理(即映射网络存在定理),一个隐含层的网络,如果隐含层的功能函数是连续函数,则网络输出可以逼近一个连续函数。具体的说,设网络有p个输入,q个输出,则其作用可以看作是由p维欧式空间到q维欧式空间的一个非线性映射。

  Kolmogorov定理表明含一个隐含层的BP前馈网络是一种通用的函数逼近器,为逼近一个连续函数,一个隐含层是足够的。当要学习不连续函数时,则需要两个隐含层,即隐含层数多两层即可,Lippmann等也给出了同样的结论。通过参考以上定理、规则,并结合试验终确定本文实现的神经网络预测器采用两个隐含层,一个输入层和一个输出层的BP网络。

  2.2 节点数

  网络的输入与输出节点数是由实际问题的本质决定的,与网络性能无关。而当像素间距离超过5时,像素之间的相关性就很小,并且在图像的某一个区域内,色度信息不会突变,因此,本文设计的BP神经网络预测器利用与当前像素相邻的9个像素来预测当前像素,这样不仅可以利用同一色分量内像素之间的相关性,也可以利用不同色通道之间像素的相关性进行预测。邻域像素的选择如图3所示。


  对Bayer图像当前像素的预测可用下面两式表示:

  其中:(k,l)∈{(一3,0),(一2,一1),(一2,0),(一1,一2),(一1,一1),(一1,0),(0,一3),(0,一2),(0,一1)},x(i,j)为当前像素的真实值;互(i,j)是当前像素的预测值,e(i,j)是预测误差。预测函数f用神经网络实现。因此,输入层有9个神经元。而网络的输出即是神经网络预测器对当前像素的预测值,因此输出层有1个神经元。

  实际上,隐含层神经元数取决于训练样本数的多少、噪声量的大小及网络学习的输入一输出函数关系或分类关系的复杂程度。对许多应用场合均适用的一条有关确定隐结点数的规则即所谓的几何金字塔规则(geometric pyramidrule):从输入层到输出层,结点数不断减少,其形好似金字塔,如图4所示。

  本文通过大量实验,终确定神经网络预测器的隐含层具有9个神经元,第二隐含层具有6个神经元。至此,神经网络预测器结构已经确定,如图5所示。

  2.3 传输函数

  在神经网络图像处理中,常使用的传输函数有两大类:

  (1)线性传输函数;

  (2)非线性传输函数。

  线性传输函数的变换较简单,其输出相对于输入呈线性增长,因而函数输入范围较小,且它不具有可微分性,这对于具有非线性特性的图像信息来说并不适用。经典的BP算法采用sigmoid函数,其输出的动态范围为[0,1],sigmoid和其导数为式1和式2:

  Tawel等提出了一种动态调整温度系数的方法,即在sigmoid函数中加入阈值和温度系数,如式3所示:

  式中θ称为阚值,λ称为温度系数。

  2.4 权值和阈值的初始化

  权值和偏置值的初始化一般有如下几种方法:

  (1)随机初始化。

  (2)逐步搜索法。

  (3)根据Nguyen-Widrow初始化算法为层产生初始权重和偏置值,使得每层神经元的活动区域能大致平坦的分布在输入空间。

  2.5 输入样本

  采集数据样本时主要考虑两方面:

  (1)数据样本要充分。

  (2)减小数据样本的冗余度。

  本文设计神经网络预测器时,采用的训练图像都是和测试图像类似的自认图像,包括人物,建筑物,风景,动植物等24bits的全彩色图像,这些全彩图像采用CFA图像。然后将每幅CFA训练图像转化成的归一化的输入训练的80%作为训练样本,其余的20%作为验证样本。

  2.6 归一化

  即通过简单的线性变换,将网络的输入和输出数据化为[0,1]区间或[一1,1]区间的数。

  通过大量试验并结合所采用的传输函数的特性发现将输入输出限制在[0.2,0.9]网络可以取得较好的预测效果,归一化方法如式4所示:

  式中,x即原始输入,x′是归一化后的输入。

  网络得到预测值时,按式5即可将预测结果映射到[0,255]之间:


  式中,net是神经网络预测器的输出,y是映射后的输出。

  3 实验结果分析

  训练好的多层前馈网络,具有预测*价功能。可将多层前传网络看作一“黑箱”,将由实测获得的输入和输出数据作为样本送入“黑箱”中让其学习,各输入变量对输出变量的影响在对样本的学习过程中由“黑箱”自动记录下来。由于节点神经元传递函数是非线性的,因此,“黑箱”也具有非线性。整个学习过程就是预测模型的建立过程,只要节点数和训练样本数足够多,“黑箱”便能实现对任意输入的输出预测。



  由表1可以看出由于神经网络预测器可以利用不同色分量的像素间的相关性和高阶特性,以及神经网络本身的非线性,它得到的误差图像的熵的平均值,为5.2408,证实了神经网络预测器相对于结构分离法和插值法的有效性,同时其结构简单,易于硬件实现。


  
上一篇:基于FPGA的航空总线协议接口设计
下一篇:基于802.11a标准的5 GHz振荡器设计

免责声明: 凡注明来源本网的所有作品,均为本网合法拥有版权或有权使用的作品,欢迎转载,注明出处。非本网作品均来自互联网,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。

相关技术资料