KFCM算法的matlab程序

在“聚类——KFCM”这篇文章中已经介绍了KFCM算法,现在用matlab程序对iris数据库进行简单的实现,并求其准确度。

作者:凯鲁嘎吉 - 博客园 http://www.cnblogs.com/kailugaji/

1.采用iris数据库

iris_data.txt

  1. 5.1 3.5 1.4 0.2
  2. 4.9 3 1.4 0.2
  3. 4.7 3.2 1.3 0.2
  4. 4.6 3.1 1.5 0.2
  5. 5 3.6 1.4 0.2
  6. 5.4 3.9 1.7 0.4
  7. 4.6 3.4 1.4 0.3
  8. 5 3.4 1.5 0.2
  9. 4.4 2.9 1.4 0.2
  10. 4.9 3.1 1.5 0.1
  11. 5.4 3.7 1.5 0.2
  12. 4.8 3.4 1.6 0.2
  13. 4.8 3 1.4 0.1
  14. 4.3 3 1.1 0.1
  15. 5.8 4 1.2 0.2
  16. 5.7 4.4 1.5 0.4
  17. 5.4 3.9 1.3 0.4
  18. 5.1 3.5 1.4 0.3
  19. 5.7 3.8 1.7 0.3
  20. 5.1 3.8 1.5 0.3
  21. 5.4 3.4 1.7 0.2
  22. 5.1 3.7 1.5 0.4
  23. 4.6 3.6 1 0.2
  24. 5.1 3.3 1.7 0.5
  25. 4.8 3.4 1.9 0.2
  26. 5 3 1.6 0.2
  27. 5 3.4 1.6 0.4
  28. 5.2 3.5 1.5 0.2
  29. 5.2 3.4 1.4 0.2
  30. 4.7 3.2 1.6 0.2
  31. 4.8 3.1 1.6 0.2
  32. 5.4 3.4 1.5 0.4
  33. 5.2 4.1 1.5 0.1
  34. 5.5 4.2 1.4 0.2
  35. 4.9 3.1 1.5 0.2
  36. 5 3.2 1.2 0.2
  37. 5.5 3.5 1.3 0.2
  38. 4.9 3.6 1.4 0.1
  39. 4.4 3 1.3 0.2
  40. 5.1 3.4 1.5 0.2
  41. 5 3.5 1.3 0.3
  42. 4.5 2.3 1.3 0.3
  43. 4.4 3.2 1.3 0.2
  44. 5 3.5 1.6 0.6
  45. 5.1 3.8 1.9 0.4
  46. 4.8 3 1.4 0.3
  47. 5.1 3.8 1.6 0.2
  48. 4.6 3.2 1.4 0.2
  49. 5.3 3.7 1.5 0.2
  50. 5 3.3 1.4 0.2
  51. 7 3.2 4.7 1.4
  52. 6.4 3.2 4.5 1.5
  53. 6.9 3.1 4.9 1.5
  54. 5.5 2.3 4 1.3
  55. 6.5 2.8 4.6 1.5
  56. 5.7 2.8 4.5 1.3
  57. 6.3 3.3 4.7 1.6
  58. 4.9 2.4 3.3 1
  59. 6.6 2.9 4.6 1.3
  60. 5.2 2.7 3.9 1.4
  61. 5 2 3.5 1
  62. 5.9 3 4.2 1.5
  63. 6 2.2 4 1
  64. 6.1 2.9 4.7 1.4
  65. 5.6 2.9 3.6 1.3
  66. 6.7 3.1 4.4 1.4
  67. 5.6 3 4.5 1.5
  68. 5.8 2.7 4.1 1
  69. 6.2 2.2 4.5 1.5
  70. 5.6 2.5 3.9 1.1
  71. 5.9 3.2 4.8 1.8
  72. 6.1 2.8 4 1.3
  73. 6.3 2.5 4.9 1.5
  74. 6.1 2.8 4.7 1.2
  75. 6.4 2.9 4.3 1.3
  76. 6.6 3 4.4 1.4
  77. 6.8 2.8 4.8 1.4
  78. 6.7 3 5 1.7
  79. 6 2.9 4.5 1.5
  80. 5.7 2.6 3.5 1
  81. 5.5 2.4 3.8 1.1
  82. 5.5 2.4 3.7 1
  83. 5.8 2.7 3.9 1.2
  84. 6 2.7 5.1 1.6
  85. 5.4 3 4.5 1.5
  86. 6 3.4 4.5 1.6
  87. 6.7 3.1 4.7 1.5
  88. 6.3 2.3 4.4 1.3
  89. 5.6 3 4.1 1.3
  90. 5.5 2.5 4 1.3
  91. 5.5 2.6 4.4 1.2
  92. 6.1 3 4.6 1.4
  93. 5.8 2.6 4 1.2
  94. 5 2.3 3.3 1
  95. 5.6 2.7 4.2 1.3
  96. 5.7 3 4.2 1.2
  97. 5.7 2.9 4.2 1.3
  98. 6.2 2.9 4.3 1.3
  99. 5.1 2.5 3 1.1
  100. 5.7 2.8 4.1 1.3
  101. 6.3 3.3 6 2.5
  102. 5.8 2.7 5.1 1.9
  103. 7.1 3 5.9 2.1
  104. 6.3 2.9 5.6 1.8
  105. 6.5 3 5.8 2.2
  106. 7.6 3 6.6 2.1
  107. 4.9 2.5 4.5 1.7
  108. 7.3 2.9 6.3 1.8
  109. 6.7 2.5 5.8 1.8
  110. 7.2 3.6 6.1 2.5
  111. 6.5 3.2 5.1 2
  112. 6.4 2.7 5.3 1.9
  113. 6.8 3 5.5 2.1
  114. 5.7 2.5 5 2
  115. 5.8 2.8 5.1 2.4
  116. 6.4 3.2 5.3 2.3
  117. 6.5 3 5.5 1.8
  118. 7.7 3.8 6.7 2.2
  119. 7.7 2.6 6.9 2.3
  120. 6 2.2 5 1.5
  121. 6.9 3.2 5.7 2.3
  122. 5.6 2.8 4.9 2
  123. 7.7 2.8 6.7 2
  124. 6.3 2.7 4.9 1.8
  125. 6.7 3.3 5.7 2.1
  126. 7.2 3.2 6 1.8
  127. 6.2 2.8 4.8 1.8
  128. 6.1 3 4.9 1.8
  129. 6.4 2.8 5.6 2.1
  130. 7.2 3 5.8 1.6
  131. 7.4 2.8 6.1 1.9
  132. 7.9 3.8 6.4 2
  133. 6.4 2.8 5.6 2.2
  134. 6.3 2.8 5.1 1.5
  135. 6.1 2.6 5.6 1.4
  136. 7.7 3 6.1 2.3
  137. 6.3 3.4 5.6 2.4
  138. 6.4 3.1 5.5 1.8
  139. 6 3 4.8 1.8
  140. 6.9 3.1 5.4 2.1
  141. 6.7 3.1 5.6 2.4
  142. 6.9 3.1 5.1 2.3
  143. 5.8 2.7 5.1 1.9
  144. 6.8 3.2 5.9 2.3
  145. 6.7 3.3 5.7 2.5
  146. 6.7 3 5.2 2.3
  147. 6.3 2.5 5 1.9
  148. 6.5 3 5.2 2
  149. 6.2 3.4 5.4 2.3
  150. 5.9 3 5.1 1.8

iris_id.txt

  1. 0
  2. 0
  3. 0
  4. 0
  5. 0
  6. 0
  7. 0
  8. 0
  9. 0
  10. 0
  11. 0
  12. 0
  13. 0
  14. 0
  15. 0
  16. 0
  17. 0
  18. 0
  19. 0
  20. 0
  21. 0
  22. 0
  23. 0
  24. 0
  25. 0
  26. 0
  27. 0
  28. 0
  29. 0
  30. 0
  31. 0
  32. 0
  33. 0
  34. 0
  35. 0
  36. 0
  37. 0
  38. 0
  39. 0
  40. 0
  41. 0
  42. 0
  43. 0
  44. 0
  45. 0
  46. 0
  47. 0
  48. 0
  49. 0
  50. 0
  51. 1
  52. 1
  53. 1
  54. 1
  55. 1
  56. 1
  57. 1
  58. 1
  59. 1
  60. 1
  61. 1
  62. 1
  63. 1
  64. 1
  65. 1
  66. 1
  67. 1
  68. 1
  69. 1
  70. 1
  71. 1
  72. 1
  73. 1
  74. 1
  75. 1
  76. 1
  77. 1
  78. 1
  79. 1
  80. 1
  81. 1
  82. 1
  83. 1
  84. 1
  85. 1
  86. 1
  87. 1
  88. 1
  89. 1
  90. 1
  91. 1
  92. 1
  93. 1
  94. 1
  95. 1
  96. 1
  97. 1
  98. 1
  99. 1
  100. 1
  101. 2
  102. 2
  103. 2
  104. 2
  105. 2
  106. 2
  107. 2
  108. 2
  109. 2
  110. 2
  111. 2
  112. 2
  113. 2
  114. 2
  115. 2
  116. 2
  117. 2
  118. 2
  119. 2
  120. 2
  121. 2
  122. 2
  123. 2
  124. 2
  125. 2
  126. 2
  127. 2
  128. 2
  129. 2
  130. 2
  131. 2
  132. 2
  133. 2
  134. 2
  135. 2
  136. 2
  137. 2
  138. 2
  139. 2
  140. 2
  141. 2
  142. 2
  143. 2
  144. 2
  145. 2
  146. 2
  147. 2
  148. 2
  149. 2
  150. 2

2.matlab程序

My_KFCM.m

  1. function label_1=My_KFCM(K,sigma)
  2. %输入K:聚类数,sigma:高斯核函数的参数
  3. %输出:label_1:聚的类, para_miu_new:模糊聚类中心μ,responsivity:模糊隶属度
  4. format long
  5. eps=1e-4; %定义迭代终止条件的eps
  6. alpha=2; %模糊加权指数,[1,+无穷)
  7. max_iter=100; %最大迭代次数
  8. data=dlmread('E:\www.cnblogs.com\kailugaji\data\iris\iris_data.txt');
  9. %----------------------------------------------------------------------------------------------------
  10. %对data做最大-最小归一化处理
  11. [data_num,~]=size(data);
  12. X=(data-ones(data_num,1)*min(data))./(ones(data_num,1)*(max(data)-min(data)));
  13. [X_num,X_dim]=size(X);
  14. %----------------------------------------------------------------------------------------------------
  15. %随机初始化K个聚类中心
  16. rand_array=randperm(X_num); %产生1~X_num之间整数的随机排列
  17. para_miu=X(rand_array(1:K),:); %随机排列取前K个数,在X矩阵中取这K行作为初始聚类中心
  18. responsivity=zeros(X_num,K);
  19. R_up=zeros(X_num,K);
  20. % ----------------------------------------------------------------------------------------------------
  21. % KFCM算法
  22. for t=1:max_iter
  23. responsivity_new=responsivity; %上一步的隶属度矩阵
  24. %欧氏距离,计算(X-para_miu)^2=X^2+para_miu^2-2*para_miu*X',矩阵大小为X_num*K
  25. distant=(sum(X.*X,2))*ones(1,K)+ones(X_num,1)*(sum(para_miu.*para_miu,2))'-2*X*para_miu';
  26. %高斯核函数,X_num*K的矩阵
  27. kernel_fun=exp((-distant)/(2*sigma*sigma));
  28. %更新隶属度矩阵X_num*K
  29. for i=1:X_num
  30. for j=1:K
  31. if kernel_fun(i,j)==1
  32. responsivity_new(i,j)=1./sum(responsivity_new(i,:)==0);
  33. else
  34. R_up(i,j)=(1-kernel_fun(i,j)).^(-1/(alpha-1)); %隶属度矩阵的分子部分
  35. responsivity_new(i,j)= R_up(i,j)./sum( R_up(i,:),2);
  36. end
  37. end
  38. end
  39. %目标函数值
  40. %fitness(t)=2*sum(sum((1-kernel_fun).*(responsivity.^(alpha))));
  41. %更新聚类中心K*X_dim
  42. miu_up=((kernel_fun.*responsivity_new)'.^(alpha))*X; %μ的分子部分
  43. para_miu=miu_up./((sum((kernel_fun.*responsivity_new).^(alpha)))'*ones(1,X_dim));
  44. if t>1
  45. %if abs(fitness(t)-fitness(t-1))<eps
  46. if norm(responsivity_new-responsivity)<=eps
  47. break;
  48. end
  49. end
  50. end
  51. %iter=t; %实际迭代次数
  52. [~,label_1]=max(responsivity_new,[],2);

succeed.m

  1. function accuracy=succeed(K,id)
  2. %输入K:聚的类,id:训练后的聚类结果,N*1的矩阵
  3. N=size(id,1); %样本个数
  4. p=perms(1:K); %全排列矩阵
  5. p_col=size(p,1); %全排列的行数
  6. new_label=zeros(N,p_col); %聚类结果的所有可能取值,N*p_col
  7. num=zeros(1,p_col); %与真实聚类结果一样的个数
  8. real_label=dlmread('E:\www.cnblogs.com\kailugaji\data\iris\iris_id.txt');
  9. %将训练结果全排列为N*p_col的矩阵,每一列为一种可能性
  10. for i=1:N
  11. for j=1:p_col
  12. for k=1:K
  13. if id(i)==k
  14. new_label(i,j)=p(j,k)-1; %iris数据库,0 1 2
  15. end
  16. end
  17. end
  18. end
  19. %与真实结果比对,计算精确度
  20. for j=1:p_col
  21. for i=1:N
  22. if new_label(i,j)==real_label(i)
  23. num(j)=num(j)+1;
  24. end
  25. end
  26. end
  27. accuracy=max(num)/N;

Eg_KFCM.m

  1. function ave_acc_KFCM=Eg_KFCM(K,sigma,max_iter)
  2. %输入K:聚的类,max_iter是最大迭代次数,sigma:高斯核函数的参数
  3. %输出ave_acc_KFCM:迭代max_iter次之后的平均准确度
  4. s=0;
  5. for i=1:max_iter
  6. label_1=My_KFCM(K,sigma);
  7. accuracy=succeed(K,label_1);
  8. s=s+accuracy;
  9. end
  10. ave_acc_KFCM=s/max_iter;

3.结果

  1. >> ave_acc_KFCM=Eg_KFCM(3,150,50)
  2.  
  3. ave_acc_KFCM =
  4.  
  5. 0.893333333333333

KFCM算法的matlab程序的更多相关文章

  1. KFCM算法的matlab程序(用FCM初始化聚类中心)

    KFCM算法的matlab程序(用FCM初始化聚类中心) 在“聚类——KFCM”这篇文章中已经介绍了KFCM算法,现在用matlab程序对iris数据库进行实现,用FCM初始化聚类中心,并求其准确度与 ...

  2. GMM算法的matlab程序

    GMM算法的matlab程序 在“GMM算法的matlab程序(初步)”这篇文章中已经用matlab程序对iris数据库进行简单的实现,下面的程序最终的目的是求准确度. 作者:凯鲁嘎吉 - 博客园 h ...

  3. GMM算法的matlab程序(初步)

    GMM算法的matlab程序 在https://www.cnblogs.com/kailugaji/p/9648508.html文章中已经介绍了GMM算法,现在用matlab程序实现它. 作者:凯鲁嘎 ...

  4. FCM算法的matlab程序2

    FCM算法的matlab程序2 在“FCM算法的matlab程序”这篇文章中已经用matlab程序对iris数据库进行实现,并求解准确度.下面的程序是另一种方法,是最常用的方法:先初始化聚类中心,在进 ...

  5. FCM算法的matlab程序

    FCM算法的matlab程序 在“FCM算法的matlab程序(初步)”这篇文章中已经用matlab程序对iris数据库进行简单的实现,下面的程序最终的目的是求准确度. 作者:凯鲁嘎吉 - 博客园 h ...

  6. K-means算法的matlab程序

    K-means算法的matlab程序 在“K-means算法的matlab程序(初步)”这篇文章中已经用matlab程序对iris数据库进行简单的实现,下面的程序最终的目的是求准确度. 作者:凯鲁嘎吉 ...

  7. FCM算法的matlab程序(初步)

    FCM算法的matlab程序 在https://www.cnblogs.com/kailugaji/p/9648430.html文章中已经介绍了FCM算法,现在用matlab程序实现它. 作者:凯鲁嘎 ...

  8. K-means算法的matlab程序(初步)

    K-means算法的matlab程序 在https://www.cnblogs.com/kailugaji/p/9648369.html 文章中已经介绍了K-means算法,现在用matlab程序实现 ...

  9. ISODATA聚类算法的matlab程序

    ISODATA聚类算法的matlab程序 作者:凯鲁嘎吉 - 博客园 http://www.cnblogs.com/kailugaji/ 参考:Kmeans及ISODATA算法的matlab实现 算法 ...

随机推荐

  1. RDD内存迭代原理(Resilient Distributed Datasets)---弹性分布式数据集

    Spark的核心RDD Resilient Distributed Datasets(弹性分布式数据集)   Spark运行原理与RDD理论 Spark与MapReduce对比,MapReduce的计 ...

  2. c# 怎么读取web.config中的配置项

    ConfigurationManager.AppSettings["templateId"]

  3. springMVC_06数据的处理

    一.提交数据的处理 *springmvc是单例的 1. 提交的域名称和处理方法的参数一致即可 提交的数据 处理方法 2.如果域名城和参数名不一致,在方法内加上域名称eg.(RequestParam(“ ...

  4. json接口返回值

    SpringBoot响应客户端渲染数据 1.SpringBoot构造并且返回一个json对象 首先,我们在父包下新建一个pojo的包,并新建一个User类  IDEA自动生成对应的get/set,然后 ...

  5. 快速掌握JavaScript面试基础知识(二)

    译者按: 总结了大量JavaScript基本知识点,很有用! 原文: The Definitive JavaScript Handbook for your next developer interv ...

  6. 如何处理Express异常?

    译者按:根据墨菲定律:“有可能出错的事情,就会出错”.那么,既然代码必然会出错,我们就应该处理好异常. 原文: How to handle errors in Express 译者:Fundebug ...

  7. PHP无限极分类原理

    1.递归:程序调用自身的编程技巧称为递归 2.案例: /** * @param 递归 $[name] */ function deeploop(&$i=1){ echo $i; $i++; i ...

  8. Angular6+ng-zorro实现登录页面

    一.效果图 二.html代码 <div class="login-container"> <div class="login-box"> ...

  9. js 时间戳转换为‘yyyy-MM-dd hh:mm’格式(es6语法)

    function formatDate(date,fmt) { if(/(y+)/.test(fmt)){ fmt = fmt.replace(RegExp.$1,(date.getFullYear( ...

  10. vue从入门到进阶:Class 与 Style 绑定(四)

    绑定 HTML Class 对象语法 ①.添加单个class: <div v-bind:class="{ active: isActive }"></div> ...