感知器神经网络模型与学习算法
第一部分 单层感知器原理感知器是美国学者在1957年首次提出的作为有导师学习的神经网络模型,单层感知器是指包含一个突触权值可调的神经元的感知器模型,它的学习算法是Rosenblatt在1958年提出的,感知器网络是神经网络用来进行模式识别的最简单模型,属于前向神经网络类型,但是仅由单个神经元组成的单层感知器只能用来实现线性可分的两类模式的识别。
感知器网络的模型如下图所示:
感知器网络的学习算法:
单层感知器网络的学习算法是基于迭代的思想,通常是采用误差校正规则的学习算法,算法的学习过程为:
第二部分 MATLAB相关函数 newp() 生成一个感知机 init() 初始化一个神经网络
mae() 平均绝对误差性能函数
hardlim() 硬限幅传输函数
hardlims() 对称硬限幅传输函数
plotpv() 在坐标图上绘出样本点
plotpc() 在已绘制的图上加分类线
train() 神经网络训练函数
learnp() 感知机的学习函数
1earnpn() 标准化感知机的学习函数
adapt() 神经网络自适应调整函数
sim() 神经网络仿真函数
netsum() 输入求和函数
第三部分 相关代码
%创建一个有两个输入、样本数据的取值范围都在[-1,1]之间,并且网络只有一个神经元的感
%知器神经网络
net=newp([-1 1;-1 1],1);
%设置网络的最大训练次数为20次,即训练20次后结束训练
net.trainParam.epochs = 20;
%使用训练函数对创建的网络进行训练
net=train(net,P,T);
%对训练后的网络进行仿真,即根据训练后的网络和样本数据给出输出
Y=sim(net,P)
%计算网络的平均绝对误差,表示网络错误分类
E1=mae(Y-T)
%给定测试数据,检测训练好的神经网络的性能
Q=;
%使用测试数据,对网络进行仿真,仿真输出即为分类的结果
Y1=sim(net,Q)
%创建一个新的绘图窗口
求问其中的P是什么意思?为什么直接输入到MATLAB会有问题?
页:
[1]