Python案例 | 使用K-means 聚类算法提取图像中的颜色

假如我们需要提取下图中的颜色,可以通过使用 K-means 聚类算法对图像进行颜色聚类分析,并生成一个基于聚类中心(即最具代表性的颜色)的RGB值和调色板。

复制代码
# 通过使用 K-means 聚类算法对图像进行颜色聚类分析,并生成一个基于聚类中心(即最具代表性的颜色)的RGB值和调色板。
# 导入必要的库
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.image as mpimg
from sklearn.cluster import KMeans

# 读取图像
image = mpimg.imread('poland-landscape.jpg')

# 获取图像尺寸
w, h, d = image.shape
pixels = image.reshape(w * h, d)

# K-means聚类,n_init设置为auto
n_colors = 15
kmeans = KMeans(n_clusters=n_colors, random_state=42, n_init='auto').fit(pixels)

# 获取聚类中心(调色板)
palette = np.uint8(kmeans.cluster_centers_)
print(palette)
# 显示调色板
plt.imshow([palette])
plt.axis('off')
plt.savefig('rgb_color_chart.png', dpi=300, bbox_inches='tight')
plt.show()

运行结果如下:

聚类得到的15个RGB值如下:

复制代码
[[  9  43  77]
 [ 70 165 209]
 [145 118  72]
 [ 47 122 160]
 [154 157 153]
 [ 11  26  38]
 [ 79  91  93]
 [212 164  37]
 [ 43  58  64]
 [231 227 217]
 [  6 125 184]
 [216 172 110]
 [ 95  78  39]
 [105 133 146]
 [ 20  78 118]]

参考资料:

https://www.douyin.com/note/7413545987140095241

相关推荐
xiaohanbao092 分钟前
day29 python深入探索类装饰器
开发语言·python·学习·机器学习·pandas
轮到我狗叫了8 分钟前
力扣310.最小高度树(拓扑排序,无向图),力扣.加油站力扣.矩阵置零力扣.二叉树中的最大路径和
算法·leetcode·职场和发展
埃菲尔铁塔_CV算法11 分钟前
深度学习驱动下的目标检测技术:原理、算法与应用创新(二)
深度学习·算法·目标检测
wuqingshun31415914 分钟前
经典算法 (A/B) mod C
c语言·开发语言·c++·算法·蓝桥杯
白杆杆红伞伞17 分钟前
04_决策树
算法·决策树·机器学习
爱coding的橙子21 分钟前
算法刷题Day9 5.18:leetcode定长滑动窗口3道题,结束定长滑动窗口,用时1h
算法·leetcode·职场和发展
姬公子52125 分钟前
leetcodehot100刷题——排序算法总结
数据结构·c++·算法·排序算法
CryptoRzz1 小时前
股票数据源对接技术指南:印度尼西亚、印度、韩国
数据库·python·金融·数据分析·区块链
AndrewHZ1 小时前
【图像处理基石】OpenCV中都有哪些图像增强的工具?
图像处理·opencv·算法·计算机视觉·滤波·图像增强·颜色科学
KangkangLoveNLP1 小时前
Llama:开源的急先锋
人工智能·深度学习·神经网络·算法·机器学习·自然语言处理·llama