第六章实验2

import numpy as np
from sklearn.cluster import KMeans
import matplotlib.pyplot as plt
from PIL import Image

im = Image.open('media/gyy1.jpeg') #此处照片换自己的路径
image = np.array(im).astype(np.float32) / 255.0
image = image[:,:, :3]  # Ensure we have 3 channels (RGB)
image_v = image.reshape(-1, 3)         # Flatten the image to a 2D array of pixels and color values
kmeans = KMeans(n_clusters=10, random_state=0)

N = image_v.shape[0]
idx = np.random.randint(0, N, size=int(N * 0.7))   # Use 70% of the data for training
image_v_train = image_v[idx]
kmeans.fit(image_v_train)
image_v_pred = kmeans.predict(image_v)
image_v_pred = image_v_pred.reshape(image.shape[:2]) # Reshape back to the original image dimensions
plt.imshow(image_v_pred)
plt.show() 
plt.imshow(image)
plt.show()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值