Python opencv 机器学习 6. KMeans k值聚类 一个特征

import cv2
import numpy as np
from matplotlib import pyplot as plt

# 只有一个特征,只由人们的身高决定T恤大小
x = np.random.randint(25, 100, 25)  # 生成25-100之间的25个随机数
y = np.random.randint(175, 255, 25)
z = np.hstack((x, y))   # 在水平方向堆叠数据,50个数据
z = z.reshape((50, 1))  # 转变为50行,1列的数据,变成列向量
z = np.float32(z)  # 转换数据类型

# 使用Kmeans函数
# 设置变量
criteria = (cv2.TERM_CRITERIA_EPS + cv2.TERM_CRITERIA_MAX_ITER, 10, 1.0)

flags = cv2.KMEANS_RANDOM_CENTERS
# 返回紧密度,标志,中心
compactness, labels, centers = cv2.kmeans(z, 2, None, criteria, 10, flags)

A = z[labels == 0]
B = z[labels == 1]

plt.hist(A, 256, [0, 256], color='r')
plt.hist(B, 256, [0, 256], color='b')
plt.hist(centers, 32, [0, 256], color='y')

plt.show()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值