人工智能KMeans聚类方法详解
本文深入浅出地详解了KMeans聚类这一经典无监督学习方法的完整实践流程:从环境准备、数据预处理、模型构建与拟合,到KMeans++初始化优化、聚类效果评估(如Calinski-Harabasz分数),再到直观的二维可视化技巧;不仅覆盖scikit-learn中fit与fit_predict的核心用法差异,还强调了参数设定(如n_clusters指定、random_state复现性)、质心解读、标签本质及高维数据降维绘图等关键细节,为读者提供了一套即学即用、兼顾原理理解与工程落地的聚类分析指南。

一、使用KMeans类执行聚类分析
当您希望对未标注的多维数据自动划分结构相似的子集时,Scikit-learn 提供的 KMeans 类可直接完成质心初始化、分配与迭代更新全过程。该方法依赖欧氏距离度量样本相似性,并以最小化簇内平方和(SSE)为目标。
1、导入必要模块:from sklearn.cluster import KMeans;import numpy as np。
2、准备输入数据 X,确保其为二维数组形状(n_samples, n_features),例如通过 make_blobs 生成模拟数据或加载真实特征矩阵。
3、实例化模型:kmeans = KMeans(n_clusters=4, random_state=42, max_iter=300),其中 n_clusters 必须由用户预先指定,random_state 保障结果可复现。
4、拟合模型:kmeans.fit(X),此操作将执行完整迭代直至收敛或达最大迭代次数。
5、获取结果:labels = kmeans.labels_ 返回每个样本所属簇的整数标签;centroids = kmeans.cluster_centers_ 返回 K 行 d 列的质心坐标数组。
二、手动调用 fit_predict 方法实现端到端聚类
fit_predict 是 fit 与 predict 的组合操作,适用于无需保留训练状态、仅需一次性获得聚类标签的场景。它避免了显式调用两次接口,提升代码简洁性与执行效率。
1、构造 KMeans 实例并设定参数,如 n_clusters=3、init='k-means++' 以改善初始质心选择质量。
2、直接调用 y_pred = kmeans.fit_predict(X),该语句内部先完成聚类中心学习,再立即对全部输入样本分配簇标签。
3、输出 y_pred 为长度等于样本数的一维数组,每个元素取值范围为 0 至 n_clusters−1,不可直接解释为类别语义,仅表示簇归属关系。
三、结合评估指标验证聚类效果
仅获取标签不足以判断聚类质量,需借助外部或内部指标量化分离度与凝聚度。Calinski-Harabasz 分数(CH 分数)是常用外部评估指标之一,值越大表明簇间离散度越高、簇内紧密度越强。
1、在已有真实标签 y_true 的情况下(如 Iris 数据集),可调用 from sklearn.metrics import adjusted_rand_score 计算调整兰德指数。
2、若无真实标签,则使用 from sklearn.metrics import calinski_harabasz_score,传入原始数据 X 和预测标签 y_pred。
3、执行 score = calinski_harabasz_score(X, y_pred),返回标量值;该分数不具绝对阈值,仅用于同数据集下不同 K 值或不同初始化策略间的相对比较。
四、采用 KMeans++ 初始化提升稳定性
KMeans 对初始质心敏感,随机初始化易陷入局部最优。KMeans++ 通过概率加权方式选取初始中心,使彼此间距更大,从而提高收敛至全局较优解的概率。
1、在 KMeans 构造时显式设置 init='k-means++',这是 scikit-learn 0.24+ 版本的默认选项。
2、该策略首步随机选一个点作为首个中心;后续每步按与已选中心最小距离的平方成正比的概率分布选取新中心。
3、相比 init='random',KMeans++ 显著降低多次运行结果的方差,尤其在簇结构不均衡时优势明显。
五、可视化聚类结果辅助判读
对于二维或经降维至二维的数据,散点图能直观呈现簇分布形态、重叠程度及质心位置,是调试与汇报的关键环节。
1、使用 matplotlib.pyplot.scatter 绘制原始数据点,c 参数设为 y_pred 实现按簇着色,s 参数控制点大小。
2、叠加质心点:plt.scatter(centroids[:, 0], centroids[:, 1], c='red', marker='X', s=200, alpha=0.9)。
3、添加坐标轴标签与标题,确保图形信息完整;注意仅当前两个特征可用于二维绘图,高维数据需先使用 PCA 或 t-SNE 降维。
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于科技周边的相关知识,也可关注golang学习网公众号。
Grafana服务指标监控与展示方案
- 上一篇
- Grafana服务指标监控与展示方案
- 下一篇
- 转转官网登录入口及网页版进入方法
-
- 科技周边 · 人工智能 | 2天前 | 人工智能 · 前端流式输出 · AI聊天 · Fetch Stream · 前端 AI聊天 流式输出 ReadableStream TextDecoder Fetch Stream
- AI 聊天流式输出前端配方:用 Fetch Stream 实现逐字渲染和中断控制
- 448浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
-
- ljg-skills
- ljg-skills 是李继刚开源的 AI 技能与提示词集合,面向大模型使用者整理了一批可复用的 prompt、角色设定和任务技能模板,适合用于学习提示词设计、搭建个人 AI 工作流和沉淀团队常用智能体能力。
- 3040次使用
-
- MELO音乐
- MELO音乐是一站式AI视频与音乐制作助手,对标suno, udio的高品质体验。提供伴奏生成、原创写词、无损导出、哼唱识曲、混音变声等全套音频与短视频编辑工具。无论是流行Kpop、电音说唱、民谣古风、摇滚儿歌还是商用轻音乐,MELO为你免费谱曲,轻松做同款!
- 2805次使用
-
- UniScribe
- UniScribe 是一款 AI 音视频转文字与内容整理工具,支持上传音频、视频文件或粘贴 YouTube 链接,自动生成转写文本、摘要、思维导图和关键问题,并支持多格式导出,适合会议记录、课程学习、访谈整理和内容创作复盘。
- 2743次使用
-
- 剧云
- 剧云是专业中文剧本创作平台,安全稳定运行十余年,集成AI编剧、剧本医生审核、人物小传、剧情关系图、大纲编写、多人协作、Word导入导出、版权管控功能,数据安全防护,轻松高效创作剧本。
- 2970次使用
-
- 万象有声
- 万象有声,一个专为有声创作者打造的新一代智能有声内容创作平台。平台提供专业的智能拆章、智能画本编辑、AI配音、AI生成音效、后期制作、智能对轨、智能审听等有声创作全流程工具,可以帮助创作者高效、低成本创作出引人入胜的有声作品。立即体验,让有声书制作更简单!
- 2920次使用
-
- AI写作工具免费版安装教程(含豆包Clawdbot)
- 2026-05-30 501浏览
-
- WPS AI能自动生成PPT吗?输入主题一键制作演示文稿
- 2026-05-27 501浏览
-
- Canva手机闪退解决方法及适配指南
- 2026-05-25 501浏览
-
- Hermes Agent依赖的工具链有哪些 必备工具链介绍
- 2026-05-05 501浏览
-
- 千问AI官网地址链接入口_千问AI官方网站登陆入口
- 2026-05-05 501浏览

