matlab实现贝叶斯分类器

更新时间:2023-06-26 22:46:16 阅读: 评论:0

matlab实现贝叶斯分类器贝叶斯详解
贝叶斯分类器
这⾥再说贝叶斯分类器的设计步骤:
1.对每个簇的数据求均值mu 和协⽅差矩阵sigma
2.对测试数据,将其对每个簇⽤均值和协⽅差矩阵求相关性。
3.将数据分类到相关性⼤的簇中。
matlab代码
分类器函数 bayesClassifer.m
function[ labels ] = bayesClassifer(trainData,trainLabel,K,testData)
%trainData 训练数据
%trainLabel 训练数据的标签
%K 训练数据的类数
%testData 测试数据
[~,dimentr]=size(trainData);
[numsts,dimente]=size(testData);
oceanicif dimentr~=dimente
disp('错误!测试数据和训练数据维数不⼀样!');
return;
end
pslmu=zeros(K,dimentr);%各个类的均值
sigma=zeros(dimentr*K,dimentr);%各个类的协⽅差
%计算各个类的均值和协⽅差
for i=1:K
mu(i,:)=mean(trainData(trainLabel==i,:));
sigma(((i-1)*dimentr+1):i*dimentr,:)=cov(trainData(trainLabel==i,:));
end
%对测试数据对各个类进⾏⽐对
labels=zeros(numsts,1);
for i=1:numsts
P=zeros(1,K);
for j=1:K
%求相关性函数
P(j)=mvnpdf(testData(i,:),mu(j,:),sigma((j-1)*dimentr+1:j*dimentr,:));
end
[~,maxIndex]=max(P);
showgoodlabels(i)=maxIndex;
end
%可视化
color = {'r.', 'g.', 'm.', 'b.', 'k.', 'y.'};
if dimentr==2
institute是什么意思subplot(1,2,1);
for i=1:K
plot(trainData(trainLabel==i,1),trainData(trainLabel==i,2),char(color(i)));
hold on;
end
title('训练数据');
subplot(1,2,2);
for i=1:K
plot(testData(labels==i,1),testData(labels==i,2),char(color(i)));
hold on;
end
title('测试数据');
elif dimentr==3
subplot(1,2,1);
for i=1:K
plot(trainData(trainLabel==i,1),trainData(trainLabel==i,2),trainData(trainLabel==i,3),char(color(i)));
britainhold on;
end
title('训练数据');
subplot(1,2,2);
for i=1:K
plot(testData(labels==i,1),testData(labels==i,2),trainData(trainLabel==i,3),char(color(i)));
melbournehold on;
end
title('测试数据');
el
ache
disp('维度不符合画图标准(1维的懒得画),咱就不画啦');
end
endspareparts
测试数据⽣成和分类。
clear;
clc;
n=100;
%⽣成训练数据
barelymu1=[2 10];
mu2=[10 2];
sigma1=[1.5 0;0 1];
sigma2=[1 0.5;0.5 2];
deli
r1=mvnrnd(mu1,sigma1,n);
r2=mvnrnd(mu2,sigma2,n);
trainData=[r1;r2];
trainLabel=[ones(100,1);2*ones(100,1)];
%⽣成测试数据
mu1=[5 5];
n=200;
sigma1=[0.5 0;0 0.5];
testData=mvnrnd(mu1,sigma1,n);
%测试
labels=bayesClassifer(trainData,trainLabel,2,testData);实验结果

本文发布于:2023-06-26 22:46:16,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/fan/90/158751.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:数据   训练   分类器   测试数据   维度   结果
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图