神经网络hopfield的学习
Hopfield神经网络使用说明。
该神经网络有两个特点:
1,输出值只有0,1
2,Hopfield没有输入(input)
这里解释一下第二个特点,什么叫没有输入?因为在使用Hopfield网络的时候,多用于图像仿真,图像仿真意思就是先给你一些标准的图像,
比如1~9的数字,然后用一些别的测试图像(模糊不清,让人识别基本靠半猜半看)去逼近标准图像。而所谓的没有输入,意思就是指,你输入的图像就是
输出结果,那么Hopfield就认为没有输入。MATLAB官方说明:Since Hopfield networks have no inputs……balabala
接着我们实际使用该神经来仿真数字图片,例子运用网络上的识别“1,2”的例子,但具体解释为原创,也在这里摒弃一些网上以讹传讹的错误解释。
Hopfield调用流程:
1 newhop()
函数功能:创建一个离散型Hopfield网络。
调用格式:net=newhop(T);
这里T代表输出,上文解释过,为什么T不是输入,T代表M*N的矩阵
2,sim()函数
% 调用格式:[Y,Af,E,perf] = sim(net,P,[],Ai,T)
% [Y,Af,E,perf] = sim(net,{Q TS},Ai,T)
%
% P,Q:测试向量的个数;
% Ai:初始的层延时,默认为0;
% T:测试向量;
% TS:测试的步数;
% Y:网络的输出矢量;
% Af:训练终止时的层延迟状态;
% E:误差矢量;
% perf:网络的性能。
这是摘自网络的解释,显然不够明确,我们用matlab是help例子说明。
Here we create a Hopfield network with two three-element
stable points T.
创建T的Hopfield网络
T = [-1 -1 1; 1 -1 1]';
net = newhop(T);
Below we check that the network is stable at these points by
using them as initial layer delay conditions. If the network is
stable we would expect that the outputs Y will be the same.
(Since Hopfield networks have no inputs, the second argument
to SIM is Q = 2 when using matrix notation).
我们用初始化数据检查构建的网络,如果网络是稳定的,则我们输出的Y就是输入的Y。
Ai = T;
[Y,Pf,Af] = sim(net,2,[],Ai);
Y
补充,sim的四个参数:
net——表示newhop建立的网络
2——表示T的列数(样本维度),这里的T是转置后的4*2维
[]——表示输入的T是矩阵形式
Ai——需要仿真的数据,这里表示用原数据测试
ps:用矩阵形式,默认神经元是一层,即Ts步长为1
接下来我们要调用多步长的方法。
To see if the network can correct a corrupted vector, run
the following code which simulates the Hopfield network for
five timesteps. (Since Hopfield networks have no inputs,
the second argument to SIM is {Q TS} = [1 5] when using cell
array notation.)
用多步长的方法,就必须要用matlab的胞元结构(cell)
这里说明一下胞元的用法:
X={x1,x2,x3……},xi可以为任何数据,也可以是cell
调用X(1)表示取到x1,可以理解为取到了一个对象;而X{1}则是x1的具体值(http://jingyan.baidu.com/article/20095761997932cb0721b485.html)
Ai = {[-0.9; -0.8; 0.7]};
[Y,Pf,Af] = sim(net,{1 5},{},Ai);
Y{1}
参数说明:
Ai——把3*1的向量封装为cell结构
{1,5}——1表示Ai的维度1,5表示用步长5,即5层神经元
{}——表示告诉函数,数据以cell格式传递进来
Ai——用原数据测试网络
重要说明sim仿真函数是横向仿真,就是以列数为仿真单位,例如在下文代码中T是数字“1“,”2”的图片合并,图片格式为12*10,合并后为24*10.
但在仿真前,由于仿真方向按照列为单位,需要转置为10*24,可以形象理解把图片横放后排列。
因此,在设置维度以12(一幅图)为单位。
函数介绍完毕,来分析一下网上给出的数字识别代码:
% ------------------------------number array---------------------------------
one=[- - - - - - - - - -;...
- - - - - - - -;- - - - - - - -;...
- - - - - - - -;- - - - - - - -;...
- - - - - - - -;- - - - - - - -;...
- - - - - - - -;- - - - - - - -;...
- - - - - - - -;- - - - - - - -;...
- - - - - - - - - -];
two=[- - - - - - - - - -;...
- -;- -;...
- - - - - - - -;- - - - - - - -;...
- -;- -;...
- - - - - - - -;- - - - - - - -;...
- -;- -;...
- - - - - - - - - -];
% --------------------------plot standard number figure--------------
subplot(,,)
imshow(imresize(one,))
title('standard number') subplot(,,)
imshow(imresize(two,))
title('standard number')
% ---------------------------creat hopfield net---------------------
T=[one;two]';
net=newhop(T);
% --------------------------generate rand noise------------------
for i=:
for j=:
a=rand;
if a<=0.1
one(i,j)=-one(i,j);
two(i,j)=-two(i,j);
end
end
end
noise_one=one
noise_two=two
% -------------------------plot noise figure----------------------------
subplot(,,)
imshow(imresize(noise_one,))
title('noise number') subplot(,,)
imshow(imresize(noise_two,))
title('noise number')
上述代买为显示图片和加入噪声后显示图片,没什么分析的必要。
% ------------------------plot identify figure---------------------------
noise1={(noise_one)'};%把图变为cell结构,并转置(横放图片排列)
tu1=sim(net,{,},{},noise1);%每12像素为一张图subplot(,,)
%转回图片并显示,这里补充一下,{3}表示有三层神经网络输出,取第三层输出值
imshow(imresize(tu1{}',20))%放大20倍
title('identify number') noise2={(noise_two)'};
tu2=sim(net,{,},{},noise2);
tu2{}'
subplot(,,)
imshow(imresize(tu2{}',20))
title('identify number')
延展:其实根据sim函数的说明,以下两端代码效果是一样的,但用cell只能是一层神经网络
%用cell
noise1={(noise_one)'};
tu1=sim(net,{,},{},noise1);
%tu1{}'
subplot(,,)
imshow(imresize(tu1{}',20))
title('identify number')
%用矩阵
noise1=(noise_one)';
tu1=sim(net,,[],noise1);
%tu1{}'
subplot(,,)
imshow(imresize(tu1',20))
title('identify number')
神经网络hopfield的学习的更多相关文章
- (转)神经网络和深度学习简史(第一部分):从感知机到BP算法
深度|神经网络和深度学习简史(第一部分):从感知机到BP算法 2016-01-23 机器之心 来自Andrey Kurenkov 作者:Andrey Kurenkov 机器之心编译出品 参与:chen ...
- 【译】神经网络与深度学习 Ch1-Section0
用神经网络识别手写数字 人类的视觉系统是是大自然的奇迹.考虑下面手写数字序列: 大多数人能够轻易地是识别出是504192.在我们大脑的每个半球都有一个基础的皮质,这就是我们熟知的V1区,它包含了14亿 ...
- [DeeplearningAI笔记]神经网络与深度学习人工智能行业大师访谈
觉得有用的话,欢迎一起讨论相互学习~Follow Me 吴恩达采访Geoffrey Hinton NG:前几十年,你就已经发明了这么多神经网络和深度学习相关的概念,我其实很好奇,在这么多你发明的东西中 ...
- 【吴恩达课后测验】Course 1 - 神经网络和深度学习 - 第二周测验【中英】
[中英][吴恩达课后测验]Course 1 - 神经网络和深度学习 - 第二周测验 第2周测验 - 神经网络基础 神经元节点计算什么? [ ]神经元节点先计算激活函数,再计算线性函数(z = Wx + ...
- 【吴恩达课后测验】Course 1 - 神经网络和深度学习 - 第一周测验【中英】
[吴恩达课后测验]Course 1 - 神经网络和深度学习 - 第一周测验[中英] 第一周测验 - 深度学习简介 和“AI是新电力”相类似的说法是什么? [ ]AI为我们的家庭和办公室的个人设备供电 ...
- 对比《动手学深度学习》 PDF代码+《神经网络与深度学习 》PDF
随着AlphaGo与李世石大战的落幕,人工智能成为话题焦点.AlphaGo背后的工作原理"深度学习"也跳入大众的视野.什么是深度学习,什么是神经网络,为何一段程序在精密的围棋大赛中 ...
- [译]深度神经网络的多任务学习概览(An Overview of Multi-task Learning in Deep Neural Networks)
译自:http://sebastianruder.com/multi-task/ 1. 前言 在机器学习中,我们通常关心优化某一特定指标,不管这个指标是一个标准值,还是企业KPI.为了达到这个目标,我 ...
- 如何理解归一化(Normalization)对于神经网络(深度学习)的帮助?
如何理解归一化(Normalization)对于神经网络(深度学习)的帮助? 作者:知乎用户链接:https://www.zhihu.com/question/326034346/answer/730 ...
- 【神经网络与深度学习】卷积神经网络(CNN)
[神经网络与深度学习]卷积神经网络(CNN) 标签:[神经网络与深度学习] 实际上前面已经发布过一次,但是这次重新复习了一下,决定再发博一次. 说明:以后的总结,还应该以我的认识进行总结,这样比较符合 ...
随机推荐
- Java基础之OOP
1. 类(类型)于对象 (1)面向过程的开发于面向对象开发的区别: 面向过程更重视流程化以及功能的开发,简单点来讲,就是按照固定的模式一步步按部就班的进行,最终达成一个功能的实现.这种模式叫做面向过程 ...
- secure boot(安全启动)下为内核模块签名
上一篇随笔中提到了如何在secure boot下安装Nvidia显卡驱动 >>上一篇随笔 如果不需要安装Nvidia显卡驱动,而且要生成密钥,可以参考>> 这篇文章 这里假设生 ...
- ffmpeg 音频转换: use ffmpeg convert the audio from stereo to mono without changing the video part
To convert the audio from stereo to mono without changing the video part, you can use FFmpeg: ffmpeg ...
- 字符串截取函数-c语言
1 #include<stdio.h> 2 #include<stdlib.h> 3 4 char* substring(char* ch,int pos,int length ...
- python第十七天-----Django初体验
Django是一个MTV框架 M:models(数据库) T:templates(放置html模版) V:views(处理用户请求) 那么传说中的MVC框架又是什么呢? M:models(数据库) V ...
- linux RPM、YUM
Linux 界的两大主流: RPM 与 DPKG distribution 代表 软件管理机制 使用指令 在线升级机制(指令) Red Hat/Fedora RPM rpm, rpmbuild YUM ...
- 转一下大牛的嵌入web页播放视频方法(转)
来自:http://www.cnblogs.com/bandry/archive/2006/10/11/526229.html 在Web页中嵌入Media Player的方法比较简单,只要用HTML中 ...
- CODE[VS] 1230 元素查找
1.题目戳这里 2.代码: #include<iostream> #include<algorithm> using namespace std; int n,m,a[1000 ...
- Android学习---ListView的点击事件,simpleAdapter和arrayadapter,SimpleCursoAdapter的原理和使用
如题,本文将介绍 listview的点击事件,simpleAdapter和arrayadapter的原理和使用. 1.ListView的注册点击事件 //注册点击事件 personListView.s ...
- python-->基础-->005-->类的三大成员:方法+属性+字段
---恢复内容开始--- 一.方法 python的方法中分为三种方法: 静态方法 动态方法(普通方法) 类方法 其中常用的方法为:静态方法和动态方法 class MyClass: def __init ...