模式识别上机实验报告
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
实验一、二维随机数的产生
1、实验目的
(1) 学习采用Matlab 程序产生正态分布的二维随机数 (2) 掌握估计类均值向量和协方差矩阵的方法
(3) 掌握类间离散度矩阵、类内离散度矩阵的计算方法
(4) 熟悉matlab 中运用mvnrnd 函数产生二维随机数等matlab 语言
2、实验原理
多元正态分布概率密度函数:
11
()()2
/21/2
1()(2)||T X X d p X e
μμπ---∑-=
∑
其中:μ是d 维均值向量:T
d E X μμμμ=={}[,,...,]12
Σ是d ×d 维协方差矩阵:T
E X X μμ∑=--[()()]
(1)估计类均值向量和协方差矩阵的估计 各类均值向量1i
i X i
m X N ω
∈
=
∑ 各类协方差矩阵1()()i
T
i i
i
X i
X X N ω
μμ∈
∑=
--∑
(2)类间离散度矩阵、类内离散度矩阵的计算
类内离散度矩阵:()()i
T
i i
i
X S X m X m ω
∈
=
--∑, i=1,2
总的类内离散度矩阵:12W S S S =+
类间离散度矩阵:1212()()T
b S m m m m =--
3、实验内容及要求
产生两类均值向量、协方差矩阵如下的样本数据,每类样本各50个。
1[2,2]μ=--,11001⎡⎤∑=⎢⎥
⎣⎦
,2[2,2]μ=,21004⎡⎤
∑=⎢⎥⎣⎦ (1)
画出样本的分布图;
(2) 编写程序,估计类均值向量和协方差矩阵;
(3) 编写程序,计算类间离散度矩阵、类内离散度矩阵; (4)
每类样本数增加到500个,重复(1)-(3)
4、实验结果(1)、样本的分布图
(2)、类均值向量、类协方差矩阵
根据matlab 程序得出的类均值向量为:
N=50 : m1=[-1.7160 -2.0374] m2=[2.1485 1.7678] N=500: m1=[-2.0379 -2.0352] m2=[2.0428 2.1270] 根据matlab 程序得出的类协方差矩阵为:
N=50: ]
0628.11354
.01354
.06428.1[
1=∑ ∑--2]5687
.40624
.00624.08800.0[
N=500:
∑--1]0344
.10162
.00162.09187.0[
∑2]9038
.30211
.00211.09939.0[
(3)、类间离散度矩阵、类内离散度矩阵
根据matlab 程序得出的类间离散度矩阵为:
N=50: ]4828
.147068.147068.149343.14[=b
S N=500: ]3233
.179843
.169843.166519.16[
b =S
根据matlab 程序得出的类内离散度矩阵为:
N=50:]0703
.533088
.73088.71052.78[
1=S ]7397.2253966.13966.18975.42[
2--=S ]8100.2789123.59123
.50026
.121[
=W S
N=500: ]5964
.5167490
.87490
.86203
.458[
1--=S ]8
.19438420.78420.70178.496[
2=S ]
4.24609071
.09071
.06381
.954[--=W S
5、结论
由mvnrnd 函数产生的结果是一个N*D 的一个矩阵,在本实验中D 是2,N 是50和500.
根据实验数据可以看出,当样本容量变多的时候,两个变量的总体误差变小,观测变量各个取值之间的差异程度减小。
6、实验程序
clc;close all ;clear all ; %parameter N = 50; N_1 = 500; mu_1 = [-2,-2]; Sigma_1 = [1,0;0,1];
r_1 = mvnrnd(mu_1,Sigma_1,N); r_11 = mvnrnd(mu_1,Sigma_1,N_1);
mu_2 = [2,2];
Sigma_2 = [1,0;0,4];
r_2 = mvnrnd(mu_2,Sigma_2,N);
r_22 = mvnrnd(mu_2,Sigma_2,N_1);
%figures
figure(1);
plot(r_1(:,1),r_1(:,2),'.');%将矩阵r_1的第一列当成横坐标,第二列当作纵坐标。
title('样本数为50时的第一类样本分布图');
figure(2);
plot(r_2(:,1),r_2(:,2),'.');
title('样本数为50时的第二类样本分布图');
figure(3);
plot(r_11(:,1),r_11(:,2),'.');
title('样本数为500时的第一类样本分布图');
figure(4);
plot(r_22(:,1),r_22(:,2),'.');
title('样本数为500时的第二类样本分布图');
%类均值向量和类协方差矩阵
m_1 = mean(r_1);%样本数为50时第一类类均值向量
m_2 = mean(r_2);%样本数为50时第二类类均值向量
m_11 = mean(r_11);%样本数为500时第一类类均值向量
m_22 = mean(r_22);%样本数为500时第二类类均值向量
sum1 = [0,0;0,0];
for n = 1:N
sum1 =sum1 + (r_1(n,:)-mu_1)'*(r_1(n,:)-mu_1);
end
E_1 = sum1/N;%样本数为50时,第一类类协方差矩阵
sum2 = [0,0;0,0];
for n = 1:N
sum2 =sum2 + (r_2(n,:)-mu_2)'*(r_2(n,:)-mu_2);
end
E_2 = sum2/N;%样本数为50时,第二类类协方差矩阵
sum3 = [0,0;0,0];
for n = 1:N_1
sum3 =sum3 + (r_11(n,:)-mu_1)'*(r_11(n,:)-mu_1);
end
E_11 = sum3/N_1;%样本数为500时,第一类类协方差矩阵
sum4 = [0,0;0,0];
for n = 1:N_1
sum4 =sum4 + (r_22(n,:)-mu_2)'*(r_22(n,:)-mu_2);
end
E_22 = sum4/N_1;%样本数为500时,第二类类协方差矩阵
%计算类间离散度和类内离散度
Sb_1 = (m_1 - m_2)'*(m_1 - m_2);%样本数为50时的,类间离散度矩阵
Sb_2 = (m_11 - m_22)'*(m_11 - m_22);%样本数为500时的,类间离散度矩阵
S_1 = [0,0;0,0];
S_2 = [0,0;0,0];
for n = 1:N
S_1 = S_1 + (r_1(n,:) - m_1)'*(r_1(n,:) - m_1);
S_2 = S_2 + (r_2(n,:) - m_2)'*(r_2(n,:) - m_2);
end
SW1 = S_1 + S_2;%样本数为50时的,总的类内离散度矩阵
S_11 = [0,0;0,0];
S_22 = [0,0;0,0];
for n = 1:N_1
S_11 = S_11 + (r_11(n,:) - m_11)'*(r_11(n,:) - m_11);
S_22 = S_22 + (r_22(n,:) - m_22)'*(r_22(n,:) - m_22);
end
SW2 = S_11 + S_22;%样本数为500时的,总的类内离散度矩阵
实验二、Fisher 线性分类器的设计
1、实验目的
(1) 掌握Fisher 线性判别方法
(2) 掌握Bayes 决策的错误率的计算 (3) 掌握分类器错误率的估算方法 (4) 对模式识别有一个初步的理解
2、实验原理
Fisher 准则基本原理:
如果在二维空间中一条直线能将两类样本分开,或者错分类很少,则同一类别样本数据在该直线的单位法向量上的投影的绝大多数都应该超过某一值。
而另一类数据的投影都应该小于(或绝大多数都小于)该值,则这条直线就有可能将两类分开。
准则:向量W 的方向选择应能使两类样本投影的均值之差尽可能大些,而使类内样本的离散程度尽可能小。
这就是Fisher 准则函数的基本思路。
y=W
T X+W0
评价投影方向W 的函数 :()T b F T
W W S W
J W W S W
=
最佳W 值的确定:求取使J F
达极大值时的 w*:*1
12()W W S m m -=-
向量*
W 就是使Fisher 准则函数)(W J F 达极大值的解,也就是按Fisher 准则将d 维X 空间投影到一维Y 空间的最佳投影方向,该向量*
W 的各分量值是对原d 维特征向量求加权和的权值。
w0确定 :012
2
m m W +=-
当W 0确定之后,则可按以下规则分类,
2
010ωω∈→->∈→->X w X W X w X W T
T
使用Fisher 准则方法确定最佳线性分界面的方法是一个著名的方法,尽管提出该方法的时间比较早,仍见有人使用。
3、实验内容及要求
考虑Fisher 线性判别方法,利用实验1中程序产生的数据(分别在各类样本数均为50及500时),计算:
1) 求解最优投影方向W ;
2) 画出表示最优投影方向的直线,并且标记出投影后的点在直线上的位置; 3) 计算投影后的阈值权;
4) 计算分类器的各类错误率及总的平均错误率;
5) 计算按最小错误率Bayes 决策的错误率(各类先验概率相同)
4、实验结果
上图可以看出在N=50时的情况下绿色的点是第一类样本点,蓝色的*给出了第二类样本点,红色的直线是最优投影方向的直线,+标出的点是W0点,直线上不同颜色代表了不同类样本点所投影的点的位置。
N=50时,类一的错误概率为0 类二的错误概率为 8% 平均错误概率为 1%
Bayes 决策错误率为0% 最佳投影方向]1432.00311
.0[*
-=W
5、结论
通过对实验结果的探究,可以得出当样本数比较大的时候类错误概率会上升。
W 的比例因子对于Fisher 判别函数没有影响的原因:
在本实验中,最重要的是W 的方向,或者说是在此方向上数据的投影,所以W 的比例因子,即它是单位向量的多少倍长就没那么重要了,不管比例因子大小是多少,在最后求投影时都会被消掉。
6、实验程序
N = 50;%样本数为50时 mu_1 = [-2,-2];
Sigma_1 = [1,0;0,1];
r_1 = mvnrnd(mu_1,Sigma_1,N);
mu_2 = [2,2];
Sigma_2 = [1,0;0,4];
r_2 = mvnrnd(mu_2,Sigma_2,N);
m_1 = mean(r_1);
m_2 = mean(r_2);
S_1 = [0,0;0,0];
S_2 = [0,0;0,0];
for n = 1:N
S_1 = S_1 + (r_1(n,:) - m_1)'*(r_1(n,:) - m_1); S_2 = S_2 + (r_2(n,:) - m_2)'*(r_2(n,:) - m_2); end
SW1 = S_1 + S_2;
W_0 = -(m_1+m_2)/2;
w = (m_1-m_2)*inv(SW1);%投影向量S
k = w(:,2)/w(:,1);%最优投影方向直线的斜率。
x=[-7:0.01:7];
y = k*(x-W_0(:,1)) + W_0(:,2);%最优投影方向直线
figure(3);
plot(r_1(:,1),r_1(:,2),'g.');
title('样本数为50时的样本分布图');
hold on;
plot(r_2(:,1),r_2(:,2),'*');
plot(W_0(1),W_0(2),'+');
plot(x,y,'r');%画出最优投影方向直线
A0=[k -1;1 k];
X0=zeros(2,N);
for n=1:N
b=[k*W_0(:,1)-W_0(:,2) r_1(n,1)+k*r_1(n,2)]';
X0(:,n)=inv(A0)*b;
end
A1=[k -1;1 k];
X1=zeros(2,N);
for n=1:N
b1=[k*W_0(:,1)-W_0(:,2) r_2(n,1)+k*r_2(n,2)]';
X1(:,n)=inv(A1)*b1;
end
plot(X0(1,:),X0(2,:),'g');
plot(X1(1,:),X1(2,:),'b');
hold off;
en1=0;en2=0;
for m=1:N
if X0(1,m) > W_0(:,1)
en1=en1+1;
end
if X1(1,m) < W_0(:,1)
en2=en2+1;
end
end
p1=en1/N; % 类一错误率
p2=en2/N; % 类二错误率
p0=(en1+en2)/(2*N); % 平均错误率
Pw1=0.5;Pw2=0.5;
Pbayes1=Pw1*p1+Pw2*p2; %Bayes决策错误率
实验三、最近邻分类器的设计
1、 实验目的
(1) 掌握最近邻分类算法 (2) 掌握k 近邻分类算法
(3) 掌握分类器错误率的估算方法
2、实验原理
(1)近邻法原理及其决策规则
最小距离分类器:将各类训练样本划分成若干子类,并在每个子类中确定代表点。
测试样本的类别则以其与这些代表点距离最近作决策。
该法的缺点:所选择的代表点并不一定能很好地代表各类,其后果将使错误率增加。
以全部训练样本作为“代表点”,计算测试样本与这些“代表点”,即所有样本的距离,并以最近邻者的类别作为决策。
最近邻法决策规则:将与测试样本最近邻样本的类别作为决策的方法称为最近邻法。
对一个C 类别问题,每类有Ni 个样本,i =1,…,C ,则第i 类ωi 的判别函数
()||||
1,2,...,min k i i i k
g X X X k N =-=
判别函数的决策规则:
若:()()
1,2,...,max i
j k
g X g X i C =
= ;则:X ∈ωj
k i X 表示是ωi 类的第k 个样本
(2)k-近邻法决策规则
在所有N 个样本中找到与测试样本的k 个最近邻者,其中各类别所占个数表示成ki,i =1,…,c 。
则决策规划是:
如果:()()
1,2,...,max i
j k
K X K X i C ==
则:X ∈ωj
3验内容及要求
还是利用实验1的程序,计算
(1) 每类产生50个样本作为训练样本;每类产生100个样本作为考试样本; (2) 按最近邻法用训练样本对考试样本分类,计算平均错误率;
(3) 按最k 近邻法(k=10)用训练样本对考试样本分类,计算平均错误率;
4、实验结果
-4-3-2-101234
-6-4
-2
2
4
6
8
训练样本分布图
-5-4-3-2-1012345
-6-4
-2
2
4
6
8
测试样本分布图
最近邻分类法错误率 =0.0150; K 紧邻分类法错误率=0.0050
5、结论
最近邻分类方法相对于K近邻分类方法来说,错误率高,其分类错误率受样本个数的影响小,K值越大,错分率应该越低,当K趋向于样本总个数时错误率应该最低,但此时计算量大。
在计算量方面,K近邻分类的计算量比最近邻分类法大。
6、实验程序
N1=100;
N2=50;
miu1=[-2;-2];
miu2=[2;2];
x1=random('normal',-2,1,1,N1);
x2=random('normal',-2,1,1,N1);
x3=random('normal',2,1,1,N1);
x4=random('normal',2,2,1,N1);
y1=random('normal',-2,1,1,N2);
y2=random('normal',-2,1,1,N2);
y3=random('normal',2,1,1,N2);
y4=random('normal',2,2,1,N2);
X1=[x1;x2]; %测试样本1
X2=[x3;x4]; %测试样本2
Y1=[y1;y2]; %训练样本1
Y2=[y3;y4]; %训练样本2
figure
plot(X1(1,:),X1(2,:),'*'); %测试样本1
hold on
plot(X2(1,:),X2(2,:),'*r'); %测试样本2
title('测试样本分布图')
figure
plot(Y1(1,:),Y1(2,:),'*'); %训练样本1
hold on
plot(Y2(1,:),Y2(2,:),'*r'); %训练样本2
title('训练样本分布图')
distance1=zeros(N1,2*N2);
distance2=zeros(N1,2*N2);
%%最近邻
erro1=0;
erro2=0;
for i=1:N1
for j=1:N2
distance1(i,j)=sqrt((X1(1,i)-Y1(1,j))^2+(X1(2,i)-Y1(2,j))^2);
distance1(i,j+N2)=sqrt((X1(1,i)-Y2(1,j))^2+(X1(2,i)-Y2(2,j))^2);
end
zuixiao=min(distance1(i,:));
for j=1:2*N2
if distance1(i,j)==zuixiao
if j>N2
erro1=erro1+1;
end
end
end
end
for i=1:N1
for j=1:N2
distance2(i,j)=sqrt((X2(1,i)-Y1(1,j))^2+(X2(2,i)-Y1(2,j))^2);
distance2(i,j+N2)=sqrt((X2(1,i)-Y2(1,j))^2+(X2(2,i)-Y2(2,j))^2);
end
zuixiao=min(distance2(i,:));
for j=1:2*N2
if distance2(i,j)==zuixiao
if j<N2
erro2=erro2+1;
end
end
end
end
erro_pingjun=(erro1+erro2)/(2*N1)
%%k近邻
k=10;
number11=zeros(N1,1);number12=zeros(N1,1);
MAX=1e5;
k_erro1=0;
for ii=1:N1
for i=1:k
zuixiao=min(distance1(ii,:));
for j=1:2*N2
if distance1(ii,j)==zuixiao
if j<=N2
number11(ii)=number11(ii)+1;
else
number12(ii)=number12(ii)+1;
end
distance1(ii,j)=MAX;
end
end
end
if number11(ii)<number12(ii)
k_erro1=k_erro1+1;
end
end
number21=zeros(N1,1);number22=zeros(N1,1);
k_erro2=0;
for ii=1:N1
for i=1:k
zuixiao=min(distance2(ii,:));
for j=1:2*N2
if distance2(ii,j)==zuixiao
if j<=N2
number21(ii)=number21(ii)+1;
else
number22(ii)=number22(ii)+1;
end
distance2(ii,j)=MAX;
end
end
end
if number21(ii)>number22(ii)
k_erro2=k_erro2+1;
end
end
k_erro_pingjun=(k_erro1+k_erro2)/(2*N1)。