OPENCV之Kmeans图像分割

本文介绍了如何利用K-means算法进行图像分割,K-means算法通过选取K个初始中心点,将数据点分配到最近的簇中,并更新簇中心。OpenCV库提供了K-means的实现,通过多次迭代和比较J值的变化来完成图像的聚类分割。通过展示原图、聚类结果图和掩码图,展示了K-means在图像分割中的应用。
摘要由CSDN通过智能技术生成

1.kmeans简介
虽然 k-means 并不能保证总是能得到全局最优解,但是对于这样的问题,像 k-means 这种复杂度的算法,这样的结果已经是很不错的了。
下面我们来总结一下 k-means 算法的具体步骤:
[1] 选定 K 个中心 \mu_k 的初值。这个过程通常是针对具体的问题有一些启发式的选取方法,或者大多数情况下采用随机选取的办法。因为前面说过 k-means 并不能保证全局最优,而是否能收敛到全局最优解其实和初值的选取有很大的关系,所以有时候我们会多次选取初值跑 k-means ,并取其中最好的一次结果。
[2] 将每个数据点归类到离它最近的那个中心点所代表的 cluster 中。
[3] 用公式 \mu_k = \frac{1}{N_k}\sum_{j\in\text{cluster}_k}x_j 计算出每个 cluster 的新的中心点。
[4] 重复第二步,一直到迭代了最大的步数或者前后的 J 的值相差小于一个阈值为止。

OPENCV中提供了kmeans具体的实现,这里就不介绍了。直接上代码。

Mat labels;
    Mat center;
    Mat p = Mat::zeros(pDoc->m_MatImage.cols*pDoc->m_MatImage.rows, 3, CV_32F);    //初始化全0矩阵
    for (int i = 0; i<pDoc->m_MatImage.cols
运用K-means算法进行图像分割, K-means算法是很典型的基于距离的聚类算法,采用距离作为相似性的评价指标,即认为两个对象的距离越近,其相似度就越大。该算法认为簇是由距离靠近的对象组成的,因此把得到紧凑且独立的簇作为最终目标。 k个初始类聚类中心点的选取对聚类结果具有较大的 公式 公式 影响,因为在该算法第一步中是随机的选取任意k个对象作为初始聚类的中心,初始地代表一个簇。该算法在每次迭代中对数据集中剩余的每个对象,根据其与各个簇中心的距离将每个对象重新赋给最近的簇。当考察完所有数据对象后,一次迭代运算完成,新的聚类中心被计算出来。如果在一次迭代前后,J的值没有发生变化,说明算法已经收敛。 算法过程如下: 1)从N个文档随机选取K个文档作为质心 2)对剩余的每个文档测量其到每个质心的距离,并把它归到最近的质心的类 3)重新计算已经得到的各个类的质心 4)迭代2~3步直至新的质心与原质心相等或小于指定阈值,算法结束 具体如下: 输入:k, data[n]; (1) 选择k个初始中心点,例如c[0]=data[0],…c[k-1]=data[k-1]; (2) 对于data[0]….data[n],分别与c[0]…c[k-1]比较,假定与c[i]差值最少,就标记为i; (3) 对于所有标记为i点,重新计算c[i]={ 所有标记为i的data[j]之和}/标记为i的个数; (4) 重复(2)(3),直到所有c[i]值的变化小于给定阈值。 折叠工作原理 K-MEANS算法的工作原理及流程 K-MEANS算法 输入:聚类个数k,以及包含 n个数据对象的数据库。 输出:满足方差最小标准的k个聚类。
OpenCV中,Kmeans聚类算法可以用于图像分割。该算法可以将图像像素分成不同的聚类,每个聚类代表了相似的像素颜色。这样可以将图像分成不同的区域,以便进行进一步的处理。要实现Kmeans聚类图像分割,您需要配置OpenCV340版本,其他版本可能需要更改属性表。 另外,如果您想要学习更多关于OpenCV的知识,可以参考NVIDIA GPU系列技术文档中的CUDA编程入门教程。此教程包含有关接口的详细使用指南和编程案例,以及有关OpenCV和PyTorch的教程。 此外,还有一种基于无监督学习的方来实现图像分类和聚类。这种方使用SIFT算法提取图像特征,然后使用KMeans聚类算法进行图像分类。通过优化源代码,可以实现将对应的图像自动分类到各自的文件夹,并优化分类准确率。该方的设计思路包括编写代码来提取图像特征、使用KMeans算法进行聚类,并将图像分类到不同的文件夹中。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [C++结合OpenCV实现Kmeans聚类图像分割的案列](https://download.csdn.net/download/qq_41828351/11012346)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [NVIDIA CUDA编程指南/opencv教程/pytorch教程(中文版)](https://download.csdn.net/download/m0_73878864/88265083)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [人工智能_项目实践_图像聚类_使用SIFT算法提取图像特征,再使用KMeans聚类算法进行图像分类](https://download.csdn.net/download/admin_maxin/85024876)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值