MATLAB模糊c均值算法FCM分类全解.ppt

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
MATLAB模糊c均值算法FCM分类全解

模糊c均值算法 FCM分类 遥感12-2班刘杰 1204090215 * 模糊c-均值聚类算法 fuzzy c-means algorithm (FCMA)或称( FCM)。在众多模糊聚类算法中,模糊C-均值( FCM) 算法应用最广泛且较成功,它通过优化目标函数得到每个样本点对所有类中心的隶属度,从而决定样本点的类属以达到自动对样本数据进行分类的目的。 FCM算法是一种基于划分的聚类算法,它的思想就是使得被划分到同一簇的对象之间相似度最大,而不同簇之间的相似度最小。模糊C均值算法是普通C均值算法的改进,普通C均值算法对于数据的划分是硬性的,而FCM则是一种柔性的模糊划分。 FCM聚类算法: 原图: 程序: %functio n [U,z,U1]=SARFCM %读入并显示图像 clear,clc IMGN=input(Input Original Image Name: ,s); img=imread(IMGN); figure imshow(img) title(原图); c=3; %分类数 m=2; %模糊度 e=0.0001; %阈值 A=double(img(:,:,1)); [n1,n2]=size(A); A=reshape(A,n1*n2,1); N=n1*n2; %样本数 U0=rand(N,c); U1=sum(U0,2 ); %求出每一行的元素总数 U2=repmat(U1,1,c);%将每一行总数复制成n*c矩阵 U=U0./U2; clear U0 U1 U2; U0=U; a=1; Z=0; while a for j=1:c V(j)=sum(U(:,j).^m.*A)/sum(U(:,j).^m); %求聚类中心 W(:,j)=abs(repmat(V(j),N,1)-A); %距离 end for i=1:N for j=1:c; if W(i,j)==0 U(i,:)=zeros(1,c); U(i,j)=1; else U(i,j)=1/sum(repmat(W(i,j),1,c)./W(i,:)).^(2/(m-1)); %求隶属度 end end end if max(max(abs(U-U0)))e a=0; end Z=Z+1 if Z100 break end end %输出图像 t=max(U,[],2); t=repmat(t,1,c); %最大值排成1*c U=double(t==U); for i=1:N F(i)= find(U(i,:)==1); end F=reshape(F,n1,n2); map=[1,1,1;0,0,0;1,0,0;0,1,0;0,0,1] figure,imshow(uint8(F),map) 算法运行过程: 算法运行过程: 算法运行过程: 成图: *

文档评论(0)

ee88870 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档