机器学习4之聚类

1.k-means算法

第一步:随机选择k个样本作为k个聚类的中心,计算每个样本到各个聚类中心的欧氏距离,将该样本分配到与之距离最近的聚类中心所在的类别中。

第二步:根据第一步所得到的聚类划分,分别计算每个聚类的几何中心,将几何中心作为新的聚类中心,重复第一步,直到计算所得几何中心与聚类中心重合或接近重合为止。

# 加载multiple3.txt,基于K均值算法完成样本的聚类

import numpy as np
import sklearn.cluster as sc
import matplotlib.pyplot as mp

data = np.loadtxt('../data/ml_data/multiple3.txt', delimiter=',')
print(data)

# k-means聚类
model = sc.KMeans(n_clusters=4)
model.fit(data)

# 聚类中心
centers = model.cluster_centers_
print(centers)

l, r = data[:, 0].min()-1, data[:, 0].max()+1
b, t = data[:, 1].min()-1, data[:, 1].max()+1

grid_x, grid_y = np.meshgrid(np.linspace(l, r, 500), np.linspace(b, t, 500))
samples = np.column_stack((grid_x.ravel(), grid_y.ravel()))
grid_z = model.predict(samples)
grid_z.shape = grid_x.shape

pred_test_y = model.predict(data)

mp.title('k-means')

mp.pcolormesh(grid_x, grid_y, grid_z, cmap='gray')
mp.scatter(data[:, 0], data[:, 1], c=pred_test_y, cmap='brg', s=80)
mp.scatter(centers[:, 0], centers[:, 1], marker='+', cmap='gold')

mp.show()

2.图像量化

import
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值