欢迎来到天天文库
浏览记录
ID:14001646
大小:166.68 KB
页数:9页
时间:2018-07-25
《模式识别——感知器准则与fisher算法实验》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、实验二感知器准则与Fisher算法实验1、【实验目的】贝叶斯分类方法是基于后验概率的大小进行分类的方法,有时需要进行概率密度函数的估计,而概率密度函数的估计通常需要大量样本才能进行,随着特征空间维数的增加,这种估计所需要的样本数急剧增加,使计算量大增。在实际问题中,人们可以不去估计概率密度,而直接通过与样本和类别标号有关的判别函数来直接将未知样本进行分类。这种思路就是判别函数法,最简单的判别函数是线性判别函数。采用判别函数法的关键在于利用样本找到判别函数的系数,模式识别课程中的感知器算法是一种求解判别函数系数的有效方法。本实验的目的是通过编制程序,实现感知器准则算法,并实现线性可分
2、样本的分类。本实验通过编制程序让初学者能够体会Fisher线性判别的基本思路,理解线性判别的基本思想,掌握Fisher线性判别问题的实质。2、[实验内容]1.实验所用样本数据如表2-1给出(其中每个样本空间(数据)为两维,x1表示第一维的值、x2表示第二维的值),编制程序实现ω1、ω2类ω2、ω3类的分类。分析分类器算法的性能。具体要求1、复习感知器算法;2、写出实现批处理感知器算法的程序1)从a=0开始,将你的程序应用在ω1和ω2的训练数据上。记下收敛的步数。2)将你的程序应用在ω2和ω3类上,同样记下收敛的步数。3)试解释它们收敛步数的差别。3、提高部分:ω3和ω4的前5个点不
3、是线性可分的,请手工构造非线性映射,使这些点在映射后的特征空间中是线性可分的,并对它们训练一个感知器分类器。分析这个分类器对剩下的(变换后的)点分类效果如何?92.Fisher准则下面表样本数据中的类别ω1和ω2计算最优方向W。画出最优方向W的直线,并标记出投影后的点在直线上的位置。3、【实验原理】线性判别函数的一般形式可表示成其中根据Fisher选择投影方向W的原则,即使原样本向量在该方向上的投影能兼顾类间分布尽可能分开,类内样本投影尽可能密集的要求,用以评价投影方向W的函数为:上面的公式是使用Fisher准则求最佳法线向量的解,该式比较重要。另外,该式这种形式的运算,我们称为线
4、性变换,其中式一个向量,是的逆矩阵,如是d维,和都是d×d维,得到的也是一个d维的向量。向量就是使Fisher准则函数达极大值的解,也就是按Fisher准则将d维X9空间投影到一维Y空间的最佳投影方向,该向量的各分量值是对原d维特征向量求加权和的权值。以上讨论了线性判别函数加权向量W的确定方法,并讨论了使Fisher准则函数极大的d维向量的计算方法,但是判别函数中的另一项尚未确定,一般可采用以下几种方法确定如或者或当与已知时可用……当W0确定之后,则可按以下规则分类,使用Fisher准则方法确定最佳线性分界面的方法是一个著名的方法,尽管提出该方法的时间比较早,仍见有人使用。4、【实
5、验内容:】1.实验所用样本数据如表2-1给出(其中每个样本空间(数据)为两维,x1表示第一维的值、x2表示第二维的值),编制程序实现ω1、ω2类ω2、ω3类的分类。分析分类器算法的性能。具体要求1、复习感知器算法;2、写出实现批处理感知器算法的程序1)从a=0开始,将你的程序应用在ω1和ω2的训练数据上。记下收敛的步数。2)将你的程序应用在ω2和ω3类上,同样记下收敛的步数。3)试解释它们收敛步数的差别。93、提高部分:ω3和ω4的前5个点不是线性可分的,请手工构造非线性映射,使这些点在映射后的特征空间中是线性可分的,并对它们训练一个感知器分类器。分析这个分类器对剩下的(变换后的)
6、点分类效果如何?5、【实验程序及结果:】(1)线性判别函数【源程序:】clearw1=[0.16.8-3.52.04.13.1-0.80.95.03.9;1.17.1-4.12.72.85.0-1.31.26.44.0];w2=[7.1-1.44.56.34.21.42.42.58.44.1;4.2-4.30.01.61.9-3.2-4.0-6.13.7-2.2];w3=[-3.00.52.9-0.1-0.4-1.3-3.41-5.11.9;-2.98.72.15.22.23.76.23.41.65.1];ww1=[ones(1,size(w1,2));w1];ww2=[ones(
7、1,size(w2,2));w2];ww3=[ones(1,size(w3,2));w3];w12=[ww1,-ww2];y=zeros(1,size(w12,2));a=[1;1;1];k=0;whileany(y<0)fori=1:size(y,2)y(i)=a'w12(:,i);enda=a+(sum((w12(:,find(y<=0)))'))';k=k+1;endakfigure(1)plot(w1(1,:),w1(2,:),'r');holdonplot(
此文档下载收益归作者所有