K-Means 聚类:数据挖掘的瑞士军刀
引言
在数据科学领域,聚类算法是一种非常重要的无监督学习方法,它能够帮助我们发现数据中的自然分组或模式。其中,K-Means 聚类算法因其简单高效而成为最常用的聚类算法之一。无论是市场细分、社交网络分析,还是图像分割等领域,K-Means 的身影无处不在。本文将带你深入了解 K-Means 聚类算法的原理与应用,从基础到实战,让你全面掌握这一强大的工具。
基础语法介绍
K-Means 聚类的核心概念
K-Means 是一种迭代的聚类算法,其目标是将数据集划分成 K 个簇(cluster),使得每个簇内部的数据点尽可能相似,而不同簇之间的数据点差异尽可能大。算法的主要步骤如下:
- 初始化:随机选择 K 个数据点作为初始的质心(centroid)。
- 分配:根据当前的质心,将每个数据点分配给最近的质心所在的簇。
- 更新:重新计算每个簇的质心,新的质心是该簇内所有数据点的平均值。
- 重复:重复执行第 2 步和第 3 步,直到质心不再发生变化或达到最大迭代次数。
基本语法规则
在 Python 中,我们可以使用 scikit-learn 库来实现 K-Means 聚类。以下是基本的语法结构:
from sklearn.cluster import KMeans# 创建 KMeans 模型
kmeans = KMeans(n_clusters=3) # n_clusters 表示要划分的簇的数量# 拟合模型
kmeans.fit(X) # X 是一个 (n_samples, n_features) 的数组# 预测簇标签
labels = kmeans.predict(X)# 获取质心
centroids = kmeans.cluster_centers_
基础实例
问题描述
假设我们有一个二维数据集,数据点分布如下图所示。我们的任务是使用 K-Means 算法将这些数据点分为 3 个簇。
代码示例
首先,我们需要导入必要的库并生成一些示例数据:
import numpy as np
import matplotlib.pyplot as plt
from sklearn.datasets import make_blobs# 生成示例数据
X, _ = make_blobs(n_samples=300, centers=3, cluster_std=0.60, random_state=0)# 绘制数据点
plt.scatter(X[:, 0], X[:, 1])
plt.show()
接下来,我们使用 K-Means 算法对数据进行聚类:
from sklearn.cluster import KMeans# 创建 KMeans 模型
kmeans = KMeans(n_clusters=3)# 拟合模型
kmeans.fit(X)# 获取簇标签
labels = kmeans.labels_# 获取质心
centroids = kmeans.cluster_centers_# 绘制聚类结果
plt.scatter(X[:, 0], X[:, 1], c=labels, cmap='viridis')
plt.scatter(centroids[:, 0], centroids[:, 1], c='red', marker='x')
plt.title('K-Means Clustering')
plt.show()
运行上述代码后,你将看到数据点被成功地分成了 3 个簇,并且每个簇的质心也被标记出来。
进阶实例
问题描述
在实际应用中,数据集往往更加复杂,可能包含更多的特征和噪声。例如,我们有一个包含多个特征的客户数据集,希望通过 K-Means 聚类来识别不同的客户群体。
高级代码实例
首先,我们加载数据并进行预处理:
import pandas as pd
from sklearn.preprocessing import StandardScaler# 加载数据
data = pd.read_csv('customer_data.csv')# 选择特征
features = ['age', 'income', 'spending_score']
X = data[features]# 数据标准化
scaler = StandardScaler()
X_scaled = scaler.fit_transform(X)
接下来,我们使用 K-Means 算法进行聚类,并评估聚类效果:
from sklearn.cluster import KMeans
from sklearn.metrics import silhouette_score# 创建 KMeans 模型
kmeans = KMeans(n_clusters=4)# 拟合模型
kmeans.fit(X_scaled)# 获取簇标签
labels = kmeans.labels_# 计算轮廓系数
silhouette_avg = silhouette_score(X_scaled, labels)
print(f'Silhouette Score: {silhouette_avg}')# 可视化聚类结果
plt.scatter(X_scaled[:, 0], X_scaled[:, 1], c=labels, cmap='viridis')
plt.title('K-Means Clustering with Multiple Features')
plt.show()
通过计算轮廓系数(Silhouette Score),我们可以评估聚类的效果。轮廓系数的范围在 -1 到 1 之间,值越接近 1 表示聚类效果越好。
实战案例
问题描述
假设你在一家电商平台工作,负责用户行为分析。你的任务是通过用户的购买历史和浏览行为,将用户分成不同的群体,以便进行更精准的营销活动。
解决方案
- 数据收集:收集用户的购买历史、浏览记录、点击率等数据。
- 数据预处理:清洗数据,处理缺失值,标准化特征。
- 特征选择:选择对用户行为影响较大的特征,如购买频率、平均消费金额、浏览时间等。
- 模型训练:使用 K-Means 算法对数据进行聚类。
- 结果分析:分析不同用户群体的行为特征,制定相应的营销策略。
代码实现
import pandas as pd
from sklearn.preprocessing import StandardScaler
from sklearn.cluster import KMeans
from sklearn.metrics import silhouette_score# 加载数据
data = pd.read_csv('user_behavior_data.csv')# 选择特征
features = ['purchase_frequency', 'average_spend', 'browse_time']
X = data[features]# 数据标准化
scaler = StandardScaler()
X_scaled = scaler.fit_transform(X)# 创建 KMeans 模型
kmeans = KMeans(n_clusters=5)# 拟合模型
kmeans.fit(X_scaled)# 获取簇标签
labels = kmeans.labels_# 计算轮廓系数
silhouette_avg = silhouette_score(X_scaled, labels)
print(f'Silhouette Score: {silhouette_avg}')# 将聚类结果添加回原始数据
data['cluster'] = labels# 分析每个簇的特征
for cluster in range(5):cluster_data = data[data['cluster'] == cluster]print(f'Cluster {cluster} Summary:')print(cluster_data[features].describe())
通过上述代码,你可以将用户分成 5 个不同的群体,并分析每个群体的特征,从而制定更精准的营销策略。
扩展讨论
选择合适的 K 值
K-Means 算法的一个关键问题是选择合适的 K 值。常用的方法有肘部法(Elbow Method)和轮廓系数法(Silhouette Score)。肘部法通过绘制不同 K 值下的误差平方和(SSE)曲线,选择曲线的“肘部”作为最佳的 K 值。轮廓系数法则通过计算每个数据点的轮廓系数,选择使平均轮廓系数最大的 K 值。
处理大规模数据
对于大规模数据集,传统的 K-Means 算法可能会遇到性能瓶颈。此时可以考虑使用 Mini-Batch K-Means 或者分布式 K-Means 算法。Mini-Batch K-Means 在每次迭代时只使用一部分数据进行更新,从而加快收敛速度。分布式 K-Means 则可以利用多台机器并行计算,进一步提高效率。
其他聚类算法
虽然 K-Means 是最常用的聚类算法之一,但它也有局限性,例如对初始质心的选择敏感、不能处理非凸形状的簇等。因此,在实际应用中,还可以考虑其他聚类算法,如 DBSCAN、层次聚类(Hierarchical Clustering)、高斯混合模型(Gaussian Mixture Model)等。
总结
K-Means 聚类算法以其简单高效的特点,在数据挖掘和机器学习领域得到了广泛应用。通过本文的介绍,相信你已经掌握了 K-Means 的基本原理和应用方法。无论你是初学者还是有经验的开发者,都可以通过实践不断深化对 K-Means 的理解,将其应用于更多复杂的场景中。希望本文能为你提供有价值的参考和启发。
相关文章:
K-Means 聚类:数据挖掘的瑞士军刀
引言 在数据科学领域,聚类算法是一种非常重要的无监督学习方法,它能够帮助我们发现数据中的自然分组或模式。其中,K-Means 聚类算法因其简单高效而成为最常用的聚类算法之一。无论是市场细分、社交网络分析,还是图像分割等领域&a…...
项目练习:若依-前端项目的目录结构介绍
文章目录 一、目录截图二、目录讲解 一、目录截图 二、目录讲解 1、首先,我们可以看到,这个VUE项目,只有一个App.vue,所以,它是一个单页面系统。 这个App.vue是根组件,root组件。 2、public目录 在Vue 3.…...
知网研学 | 知网文献(CAJ+PDF)批量下载
知网文献(CAJPDF)批量下载 一、知网研学安装二、插件及脚本安装三、CAJ批量下载四、脚本下载及PDF批量下载浏览器取消拦截窗口 一、知网研学安装 批量下载知网文件,格式为es6文件,需使用知网研学软件打开,故需先安装该…...
设计模式期末复习
一、设计模式的概念以及分类 二、设计模式的主题和意图 三、面向对象程序设计原则,记住名字,还要理解它的使用场景以及如何用? 四、松耦合、紧耦合、强关联、弱关联、静态复用、动态复用的概念,还有静态委派,动态委…...
CentOS7源码编译安装nginx+php+mysql
1.安装nginx 安装依赖 yum -y install gcc gcc-c wget automake autoconf libtool libxml2-devel libxslt-devel perl-devel perl-ExtUtils-Embed pcre-devel openssl openssl-devel 创建一个不能登录的nginx运行用户 groupadd www-data useradd -s /sbin/nologin -g www-d…...
linux CentOS系统上卸载docker
一、停止Docker服务 首先,需要停止Docker服务。使用systemctl命令来停止Docker服务: bash复制代码sudo systemctl stop docker二、卸载Docker软件包 接下来,使用CentOS的包管理器yum来卸载Docker软件包。根据安装的Docker版本和组件&#…...
css中相对定位的应用场景
元素位置微调 文本与图标组合微调:在网页设计中,经常会有文本和图标的组合,比如一个带有搜索图标的搜索框。可以使用相对定位来微调图标在搜索框内的位置。例如,有以下HTML结构: <input type"text" class…...
Android 获取屏幕物理尺寸
注:编译 sdk 需要使用 30 因为引入了 WindowMetrics、uild.VERSION_CODES.R 新 sdk 才存在的类和属性 某些场景处理 view ,对 view 显示的位置要求比较精确,通常我们使用context.getResources().getDisplayMetrics().widthPixels 获取到的宽、…...
C缺陷与陷阱 — 8 编译与链接
目录 1 程序的编译过程 2 动态链接的优缺点 2.1 动态链接的优点 2.2 动态链接的缺点 2.3 只使用动态链接 3 函数库链接的5个特殊秘密 4 警惕Interpositioning 5 产生链接器报告文件 1 程序的编译过程 程序的编译过程是将源代码转换成计算机可以执行的机器代码的过程。…...
知识分享第三十天-力扣343.(整数拆分)
343 整数拆分 给定一个正整数 n,将其拆分为至少两个正整数的和,并使这些整数的乘积最大化。 返回你可以获得的最大乘积。 示例 1: 输入: 2 输出: 1 解释: 2 1 1, 1 1 1。 示例 2: 输入: 10 输出: 36 解释: 10 3 3 4, 3 3 4 36。 说明: 你可…...
Springboot 整合DL4J 打造智能写作助手(文本生成)
项目准备 环境要求: Java 1.8或以上 Maven 或 Gradle(用于项目管理) Spring Boot框架 DL4J库(DeepLearning4J) 创建 Spring Boot 项目 使用 Spring Initializr 来生成一个新的 Spring Boot 项目。选择合适的依赖,例如…...
SPL06 基于stm32F103 HAL库驱动(软件模拟IIC)
talk is cheap, show you my code SPL06.c #include "SPL06.h"//*************全局变量*************// Factor_List* b_list; //存储过采样率对应的系数KP,KT COEF_ValueStruct Coefficient { 0 }; //存储校准系数…...
【C#】List求并集、交集、差集
值类型List List<int> intList1 new List<int>() { 1, 2, 3 };List<int> intList2 new List<int>() { 3, 4, 5 };var result intList1.Union(intList2);Console.WriteLine($"并 {string.Join(,,result)}");result intList1.Intersect(in…...
YOLOv8目标检测——详细记录使用ONNX Runtime进行推理部署C++/Python实现
概述 在之前博客中有介绍YOLOv8从环境安装到训练的完整过程,本节主要介绍ONNX Runtime的原理以及使用其进行推理加速,使用Python、C两种编程语言来实现。 https://blog.csdn.net/MariLN/article/details/143924548?spm1001.2014.3001.5501 1. ONNX Ru…...
mfc140u.dll是什么文件?如何解决mfc140u.dll丢失的相关问题
遇到“mfc140u.dll文件丢失”的错误通常影响应用程序的运行,这个问题主要出现在使用Microsoft Visual C环境开发的软件中。mfc140u.dll是一个重要的系统文件,如果它丢失或损坏,会导致相关程序无法启动。本文将简要介绍几种快速有效的方法来恢…...
Redis篇-19--运维篇1-主从复制(主从复制,读写分离,配置实现,实战案例)
1、概述 Redis的主从复制(Master-Slave Replication)是一种数据冗余机制,它允许将一台Redis服务器的数据复制到其他Redis服务器。在主从复制中,有一台主服务器(Master)和一个或多个从服务器(Sl…...
【Elasticsearch入门到落地】4、Elasticsearch的安装
接上篇《3、es与mysql的概念对比》 上一篇我们学习了Elasticsearch与Mysql的概念与区别。本篇我们来进行Elasticsearch的环境准备及软件安装。 一、环境准备 如果我们没有自己的Linux服务器,且现在正在使用的是Windows操作系统的电脑,那么首先我们需要安…...
计算无人机俯拍图像的地面采样距离(GSD)矩阵
引言 在无人机遥感、测绘和精细农业等领域,地面采样距离(Ground Sampling Distance,简称 GSD)是一个非常重要的指标。GSD 是指图像中每个像素在地面上实际代表的物理距离,通常以米或厘米为单位。GSD 决定了图像的空间…...
牛客网 SQL37查找多列排序
SQL37查找多列排序 select device_id,gpa,age from user_profile order by gpa asc,age asc#select [字段1,字段2] from [表名] order by [字段1] [升序(asc)/降序(desc)],[字段2] [升序(asc)/降序(desc)] #select:查询 #order by 排序 每日问题 如何处理对象的状…...
el-tabs标签过多
tab-position:top情况 .el-tabs__nav-wrap{overflow-x: auto ;width: 86% ;margin-left: 10px ; } 效果: tab-position:left情况 .el-tabs__nav-wrap{overflow-x: auto ;height: 高度 ;margin-top: 10px ; } 效果: 注意&…...
CTF show Web 红包题第六弹
提示 1.不是SQL注入 2.需要找关键源码 思路 进入页面发现是一个登录框,很难让人不联想到SQL注入,但提示都说了不是SQL注入,所以就不往这方面想了 先查看一下网页源码,发现一段JavaScript代码,有一个关键类ctfs…...
Leetcode 3576. Transform Array to All Equal Elements
Leetcode 3576. Transform Array to All Equal Elements 1. 解题思路2. 代码实现 题目链接:3576. Transform Array to All Equal Elements 1. 解题思路 这一题思路上就是分别考察一下是否能将其转化为全1或者全-1数组即可。 至于每一种情况是否可以达到…...
边缘计算医疗风险自查APP开发方案
核心目标:在便携设备(智能手表/家用检测仪)部署轻量化疾病预测模型,实现低延迟、隐私安全的实时健康风险评估。 一、技术架构设计 #mermaid-svg-iuNaeeLK2YoFKfao {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg…...
【第二十一章 SDIO接口(SDIO)】
第二十一章 SDIO接口 目录 第二十一章 SDIO接口(SDIO) 1 SDIO 主要功能 2 SDIO 总线拓扑 3 SDIO 功能描述 3.1 SDIO 适配器 3.2 SDIOAHB 接口 4 卡功能描述 4.1 卡识别模式 4.2 卡复位 4.3 操作电压范围确认 4.4 卡识别过程 4.5 写数据块 4.6 读数据块 4.7 数据流…...
python如何将word的doc另存为docx
将 DOCX 文件另存为 DOCX 格式(Python 实现) 在 Python 中,你可以使用 python-docx 库来操作 Word 文档。不过需要注意的是,.doc 是旧的 Word 格式,而 .docx 是新的基于 XML 的格式。python-docx 只能处理 .docx 格式…...
今日科技热点速览
🔥 今日科技热点速览 🎮 任天堂Switch 2 正式发售 任天堂新一代游戏主机 Switch 2 今日正式上线发售,主打更强图形性能与沉浸式体验,支持多模态交互,受到全球玩家热捧 。 🤖 人工智能持续突破 DeepSeek-R1&…...
tree 树组件大数据卡顿问题优化
问题背景 项目中有用到树组件用来做文件目录,但是由于这个树组件的节点越来越多,导致页面在滚动这个树组件的时候浏览器就很容易卡死。这种问题基本上都是因为dom节点太多,导致的浏览器卡顿,这里很明显就需要用到虚拟列表的技术&…...
Java数值运算常见陷阱与规避方法
整数除法中的舍入问题 问题现象 当开发者预期进行浮点除法却误用整数除法时,会出现小数部分被截断的情况。典型错误模式如下: void process(int value) {double half = value / 2; // 整数除法导致截断// 使用half变量 }此时...
论文阅读:Matting by Generation
今天介绍一篇关于 matting 抠图的文章,抠图也算是计算机视觉里面非常经典的一个任务了。从早期的经典算法到如今的深度学习算法,已经有很多的工作和这个任务相关。这两年 diffusion 模型很火,大家又开始用 diffusion 模型做各种 CV 任务了&am…...
shell脚本质数判断
shell脚本质数判断 shell输入一个正整数,判断是否为质数(素数)shell求1-100内的质数shell求给定数组输出其中的质数 shell输入一个正整数,判断是否为质数(素数) 思路: 1:1 2:1 2 3:1 2 3 4:1 2 3 4 5:1 2 3 4 5-------> 3:2 4:2 3 5:2 3…...
