谱聚类--Ng算法的Matlab简单实现

2024-06-12 20:38

本文主要是介绍谱聚类--Ng算法的Matlab简单实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


请编写一个谱聚类算法,实现“Normalized Spectral Clustering—Algorithm 3 (Ng 算法)”

结果如下


谱聚类算法核心步骤都是相同的:
•利用点对之间的相似性,构建亲和度矩阵;
•构建拉普拉斯矩阵;
•求解拉普拉斯矩阵最小的特征值对应的特征向量(通常舍弃零特征所对应的分量全相等的特征向量);
•由这些特征向量构成样本点的新特征,采用K-means等聚类方法完成最后的聚类。

采用K-means等聚类方法完成最后的聚类  意思是,对特征向量构成的矩阵T,每一行作为一个样本点,进行K均值聚类。

(1)利用点对之间的相似性,构建亲和度矩阵

构建图时,顶点的度为 simK=10,分两类kNearNum=2

[plain] view plain copy
  1. simK=10;  
  2. Wij=zeros(r,r);% weight  
  3. % calculate the weight Matrix  
  4. for k=1:r    
  5.     for n=1:r  
  6.          Wij(k,n)=exp(-norm(X(k,:)-X(n,:))^2/2/sigma);% 计算权重  
  7.     end  
  8. end  
  9.   
  10. % find the Knear  for W  
  11. Wsort=zeros(r,r);  
  12. index=zeros(r,r);  
  13. for k=1:r  
  14. %  对每一行权重排序  
  15.    [Wsort(k,:),index(k,:)]=sort(Wij(k,:));  %这句话经常不会用,记住了。     
  16. end  
  17.   
  18. W=Wij  


(2) 构建Laplace Matrix

首先需要个对角阵D,其对角元素是亲和度矩阵的每行的和,这里也就是simK*eye(r)

[html] view plain copy
  1. % D  
  2. D=simK.*eye(r);  
  3. % Laplace Matrix  
  4. L=eye(r)-D^(-0.5)*W*D^(-0.5);  
  5. L=D-W  

(3) 求解拉普拉斯矩阵最小的特征值(lamda)对应的特征向量)(通常舍弃零特征所对应的分量全相等的特征向量);

把特征向量 Vect里最小的kNearNum(聚类的个数)个用u来存储。

[html] view plain copy
  1. [Vect,lamdaMat]=eig(L);  
  2. lamda=zeros(k,1);  
  3. u=zeros(r,kNearNum);  
  4. % lamda是特征值  
  5. for k=1:r  
  6.     lamda(k)=lamdaMat(k,k);  
  7. end  
  8. % lamda  
  9. %  对lamda排序,找出最小的K个lamda对应的特征向量组成u  
  10. [sortLamda,indexLamda]=sort(lamda);   
  11. countu=0;  
  12. for k=1:kNearNum  
  13.     countu=countu+1;  
  14.     u(:,countu)=Vect(:,indexLamda(k));    
  15. end  
  16. % % T  
  17. T=zeros(r,kNearNum);% 归一化后的u  
  18. sumU=zeros(1,kNearNum);% 为了归一化u,对每列求了平方和sumU  
  19. for n=1:kNearNum  
  20.     for k=1:r  
  21.         sumU(1,n)=sumU(1,n)+u(k,n)^2;  
  22.     end  
  23. end  
  24.   
  25. for k=1:r  
  26.     for n=1:kNearNum  
  27.         T(k,n)=u(k,n)./sqrt(sumU(1,n));  
  28.     end  
  29. end  

(4)由这些特征向量构成样本点的新特征, 采用K-means等聚类方法完成最后的聚类

意思是,对特征向量构成的矩阵T,每一行作为一个样本点聚类

[html] view plain copy
A=Kmeans(T)  % key words

这篇关于谱聚类--Ng算法的Matlab简单实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1055284

相关文章

golang中slice扩容的具体实现

《golang中slice扩容的具体实现》Go语言中的切片扩容机制是Go运行时的一个关键部分,它确保切片在动态增加元素时能够高效地管理内存,本文主要介绍了golang中slice扩容的具体实现,感兴趣... 目录1. 切片扩容的触发append 函数的实现2. runtime.growslice 函数gro

golang实现动态路由的项目实践

《golang实现动态路由的项目实践》本文主要介绍了golang实现动态路由项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习... 目录一、动态路由1.结构体(数据库的定义)2.预加载preload3.添加关联的方法一、动态路由1

使用Python实现调用API获取图片存储到本地的方法

《使用Python实现调用API获取图片存储到本地的方法》开发一个自动化工具,用于从JSON数据源中提取图像ID,通过调用指定API获取未经压缩的原始图像文件,并确保下载结果与Postman等工具直接... 目录使用python实现调用API获取图片存储到本地1、项目概述2、核心功能3、环境准备4、代码实现

MySQL数据库实现批量表分区完整示例

《MySQL数据库实现批量表分区完整示例》通俗地讲表分区是将一大表,根据条件分割成若干个小表,:本文主要介绍MySQL数据库实现批量表分区的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考... 目录一、表分区条件二、常规表和分区表的区别三、表分区的创建四、将既有表转换分区表脚本五、批量转换表为分区

windows和Linux安装Jmeter与简单使用方式

《windows和Linux安装Jmeter与简单使用方式》:本文主要介绍windows和Linux安装Jmeter与简单使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Windows和linux安装Jmeter与简单使用一、下载安装包二、JDK安装1.windows设

Spring Boot 整合 Redis 实现数据缓存案例详解

《SpringBoot整合Redis实现数据缓存案例详解》Springboot缓存,默认使用的是ConcurrentMap的方式来实现的,然而我们在项目中并不会这么使用,本文介绍SpringB... 目录1.添加 Maven 依赖2.配置Redis属性3.创建 redisCacheManager4.使用Sp

Kali Linux安装实现教程(亲测有效)

《KaliLinux安装实现教程(亲测有效)》:本文主要介绍KaliLinux安装实现教程(亲测有效),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、下载二、安装总结一、下载1、点http://www.chinasem.cn击链接 Get Kali | Kal

C#使用MQTTnet实现服务端与客户端的通讯的示例

《C#使用MQTTnet实现服务端与客户端的通讯的示例》本文主要介绍了C#使用MQTTnet实现服务端与客户端的通讯的示例,包括协议特性、连接管理、QoS机制和安全策略,具有一定的参考价值,感兴趣的可... 目录一、MQTT 协议简介二、MQTT 协议核心特性三、MQTTNET 库的核心功能四、服务端(BR

SpringCloud整合MQ实现消息总线服务方式

《SpringCloud整合MQ实现消息总线服务方式》:本文主要介绍SpringCloud整合MQ实现消息总线服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、背景介绍二、方案实践三、升级版总结一、背景介绍每当修改配置文件内容,如果需要客户端也同步更新,

Dubbo之SPI机制的实现原理和优势分析

《Dubbo之SPI机制的实现原理和优势分析》:本文主要介绍Dubbo之SPI机制的实现原理和优势,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Dubbo中SPI机制的实现原理和优势JDK 中的 SPI 机制解析Dubbo 中的 SPI 机制解析总结Dubbo中