Python利用K-Means算法进行图像聚类分割实战(超详细 附源码)

需要源码和图片请点赞关注收藏后评论区留言私信~~~

图形分割就是把图像分成若干个特定的、具有独特性质的区域。并提出感兴趣目标的技术和过程,它是由图像处理到图像分析的关键步骤,本案例利用K-Means聚类方法对图像的像素进行聚类实现图像分割

打开图像文件并显示 原图像如下

 接着显示图像的信息和图像大小

显示图像的颜色模式

对图像数据进行聚类并显示每个像素的簇标号

 

 最后显示分割后的图像 如下图所示

可以看出图像可以明显的聚为三个簇 也就是三种颜色 大致可以分为三类

 部分代码如下

import numpy as np
from sklearn.cluster import KMeans
import matplotlib.pyplot as plt
import PIL.Image as Image
%matplotlib inline
img=Image.open('lena.jpg')
plt.axis('off')
plt.imshow(img)
print(img.info)
row,col=img.size
print('图像的大小:',row,col)
print('数据类型',type(img))
print( '图像的颜色模式:',img.mode)
imgData=np.array(img.getdata())
type(imgData)
pixel_vals = imgData.reshape(-1,3)
pixel_vals
km_cluster = KMeans(n_clusters=3)
label=km_cluster.fi([row,col]).T  
pic_new = Image.new("L", (row, col))  
for i in range(row): 
    for j in range(col):       
        pic_new.putpixel((i,j), int(int(256/(label[i][j]+1))))  
plt.imshow(pic_new)

 创作不易 觉得有帮助请点赞关注收藏~~~

  • 23
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论
K-means聚类算法是一种常用的无监督学习算法,用于将一组数据分成不同的簇。它通过计算数据点与各个簇中心之间的距离,并将数据点分配到距离最近的簇中心,不断地更新簇中心的位置,直到达到收敛。 针对在线学习的需求,可以参考以下实现思路: 1. 初始化簇中心:随机选择k个数据点作为初始簇中心。 2. 随机选择一个新的数据点,并计算该数据点与所有簇中心的距离。 3. 将新的数据点分配到距离最近的簇中心。 4. 更新簇中心的位置:对于每个簇,计算该簇中所有数据点的平均值,将该平均值作为新的簇中心。 5. 重复第2-4步,直到达到收敛条件,如达到指定的迭代次数或簇中心的变化小于阈值。 基于以上思路,可以使用Python编写在线学习的K-means聚类算法源码。具体实现如下: ```python import numpy as np class KMeans: def __init__(self, k, max_iter=100, tol=1e-4): self.k = k self.max_iter = max_iter self.tol = tol def fit(self, X): # 初始化簇中心 self.centroids = X[np.random.choice(range(X.shape[0]), self.k, replace=False)] for _ in range(self.max_iter): # 分配数据点到簇中心 labels = self.assign_labels(X) # 更新簇中心的位置 new_centroids = self.update_centroids(X, labels) # 判断簇中心的变化是否小于阈值 if np.linalg.norm(new_centroids - self.centroids) < self.tol: break self.centroids = new_centroids def assign_labels(self, X): distances = np.sqrt(((X[:, np.newaxis] - self.centroids) ** 2).sum(axis=2)) return np.argmin(distances, axis=1) def update_centroids(self, X, labels): new_centroids = np.zeros_like(self.centroids) for i in range(self.k): new_centroids[i] = X[labels == i].mean(axis=0) return new_centroids ``` 以上是一个简单的在线学习的K-means聚类算法源码,可以根据实际需求进行适当修改和拓展,例如添加更复杂的初始簇中心选择方法或调整更新簇中心的策略。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

showswoller

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值