对偶传播神经网络
2018-03-08 16:06
357 查看
这里有个PPT教程,大家看看!
这是一位博主给的学习资料链接,http://wenku.baidu.com/link?url=JIhrQ5tpegz_KfBEV6TT9nPL6SYBq-Msc8GzHJYgAi2rM462hTZy2QU4G7qUQYXlOdVxxHKn-FRKS5Ok9Jkc02gM2B72ySRrf9SM-mqZrT7在本人转载的CPN网络介绍类似,都很详细。特此转载
1987年,美国学者Robert Hecht-Nielsen提出了对偶传播神经网络模型 (Counter Propagation Network,CPN),CPN最早是用来实现样本选择匹配系统的。CPN 网能存储二进制或模拟值的模式对,因此这种网络模型也可用于联想存储、模式分类、函数逼近、统计分析和数据压缩等用途。
1. 网络结构与运行原理
网络结构如图所示,各层之间的神经元全互联连接。从拓扑结构看,CPN网与三层BP网络相近,但实际上CPN是由自组织网和Grossberg外星网组合而成。隐层为竞争层,采用无监督竞争学习规则,而输出层为Grossberg层,采用有监督信号的Widrow-Hoff规则或Grossberg规则学习。
网络各层按两种学习规则训练好之后,运行阶段首先向网络送入输入变量,隐含层对这些输入进行竞争计算,获胜者成为当前输入模式类的代表,同时该神经元成为如下图(a)所示的活跃神经元,输出值为1而其余神经元处于非活跃状态,输出值为0。竞争取胜的隐含神经元激励输出层神经元,使其产生如下图(b)所示的输出模式。由于竞争失败的神经元输出为0,不参与输出层的整合。因此输出就由竞争胜利的神经元的外星权重确定。
2. 学习算法
网络学习分为两个阶段:第一阶段是竞争学习算法对隐含层神经元的内星权向量进行训练;第二阶段是采用外星学习算法对隐含层的神经元的外星权向量进行训练。
(1)竞争学习算法对隐含层神经元的内星权向量进行训练
(2)采用外星学习算法对隐含层的神经元的外星权向量进行训练。
β为外星规则学习速率,为随时间下降的退火函数。O(t)为输出层神经元的输出值。
由以上规则可知,只有获胜神经元的外星权向量得到调整,调整的目的是使外星权向量不断靠近并等于期望输出,从而将该输出编码到外星权向量中。
3. 改进CPN网
(1) 双获胜神经元CPN
指的是在完成训练后的运行阶段允许隐层有两个神经元同时竞争获得胜利,这两个获胜神经元均取值为1,其他神经元则取值为0。于是有两个获胜神经元同时影响网络输出。下图给出了一个例子,表明了CPN网能对复合输入模式包含的所有训练样本对应的输出进行线性叠加,这种能力对于图像的叠加等应用十分合适。
(2) 双向CPN网
将CPN网的输入层和输出层各自分为两组如图所示。双向CPN网的优点是可以同时学习两个函数,例如:Y=f (X);X′=f (Y′)
当两个函数互逆时,有X =X′,Y =Y′。双向CPN可用于数据压缩与解压缩,可将其中一个函数f作为压缩函数,将其逆函数g作为解压缩函数。
事实上,双向CPN网并不要求两个互逆函数是解析表达的,更一般的情况是f和g是互逆的映射关系,从而可利用双向CPN实现互联想。
4. CPN网应用
下图给出了CPN网用于烟叶颜色模式分类的情况,输入样本分布在下图(a)所示的三维颜色空间中的效果,各分量分别代表烟叶的平均色调H,平均亮度L和平均饱和度S。可以看出颜色模式分为4类,分别对应红棕色,橘黄色,柠檬色和青黄色。下图(b)给出了CPN网络结构,隐层共设了10个神经元,输出层设4个神经元,学习速率为随训练时间下降的函数,经过2000次递归之后,网络分类的正确率达到96%。
5.CPN开发python实现代码
这块还没有写正在学习当中,尽快完成!
转载出处:http://blog.csdn.net/lg1259156776/
相关文章推荐
- 对偶传播神经网络
- 对偶传播神经网络(CPN)
- 神经网络的前向传播和误差反向传播(NN,RNN,LSTM)(三)
- 深度学习torch之三(神经网络的前向传播和反向传播以及损失函数的基本操作)
- 神经网络(前向传播和反向传导)
- 神经网络-前向传播
- 神经网络前向后向传播推导及实现
- 神经网络基本结构(前向传播+随机梯度下降法)
- 神经网络反向传播
- TensorFlow 深度学习框架 (1)-- 神经网络与前向传播
- TensorFlow 深度学习框架 (1)-- 神经网络与前向传播
- 深度学习笔记(二):简单神经网络,后向传播算法及实现
- TensorFlow 深度学习框架 (2)-- 反向传播优化神经网络
- 神经网络反向传播方法
- 神经网络初探:反向传播公式的简易证明
- 神经网络基础和反向传播推导
- 【模式识别】反向传播神经网络 BPNN
- 神经网络之后向传播算法
- TensorFlow 深度学习框架 (1)-- 神经网络与前向传播
- TensorFlow 深度学习框架 (1)-- 神经网络与前向传播