当前位置: 首页 > news >正文

基于蜣螂算法优化Kmeans图像分割-附代码

基于蜣螂优化Kmeans图像分割算法 - 附代码

文章目录

  • 基于蜣螂优化Kmeans图像分割算法 - 附代码
    • 1.Kmeans原理
    • 2.基于蜣螂算法的Kmeans聚类
    • 3.算法实验结果
    • 4.Matlab代码

摘要:基于蜣螂优化Kmeans图像分割算法。

1.Kmeans原理

K-Means算法是一种无监督分类算法,假设有无标签数据集:
X=[x1,x2,...,xn](1)X = [x_1,x_2,...,x_n] \tag{1} X=[x1,x2,...,xn](1)
该算法的任务是将数据集聚类成kkkC=C1,C2,...,CkC = C_1,C2,...,C_kC=C1,C2,...,Ck,最小化损失函数为:
E=∑i=1k∑x∈Ci∣∣x−ui∣∣2(2)E = \sum_{i=1}^k\sum_{x\in C_i}||x-u_i||^2 \tag{2} E=i=1kxCi∣∣xui2(2)
其中uiu_iui为簇的中心点:
ui=1∣Ci∣∑x∈Cix(3)u_i = \frac{1}{|C_i|}\sum_{x\in C_i}x \tag{3} ui=Ci1xCix(3)
要找到以上问题的最优解需要遍历所有可能的簇划分,K-Mmeans算法使用贪心策略求得一个近似解,具体步骤如下:

1.在样本中随机选取kkk个样本点充当各个簇的中心点{u1,u2,...,uk}\{u_1,u_2,...,u_k\}{u1,u2,...,uk}

2.计算所有样本点与各个簇中心之间的距离dist(xi,uj)dist(x_i,u_j)dist(xi,uj),然后把样本点划入最近的簇中xi∈unearestx_i \in u_{nearest}xiunearest

3.根据簇中已有的样本点,重新计算簇中心
ui=1∣Ci∣∑x∈Cixu_i = \frac{1}{|C_i|}\sum_{x\in C_i}x ui=Ci1xCix

4.重复2、3

K-means算法得到的聚类结果严重依赖与初始簇中心的选择,如果初始簇中心选择不好,就会陷入局部最优解.因此初始簇中心的选择非常重要。本文利用蜣螂优化算法对初始簇中心进行优化,改进其容易陷入局部最优的特点。

2.基于蜣螂算法的Kmeans聚类

蜣螂算法的具体原理参考博客:https://blog.csdn.net/u011835903/article/details/128280084

适应度函数:利用蜣螂算法改进kmeans时,以聚类中心作为蜣螂算法的优化变量,适应度函数设计如下:
fitness=∑i=1k∑x∈Ci∣∣x−ui∣∣2fitness = \sum_{i=1}^k\sum_{x\in C_i}||x-u_i||^2 fitness=i=1kxCi∣∣xui2
该适应度函数与kmeans的最小损失函数一致。

算法的具体流程如下:

1.随机抽样待分类数据点,作为蜣螂聚类候选点。

2.利用蜣螂算法搜索最小损失的的聚类点。

3.将这些聚类点作为kmeans算法的初始聚类点。

4.利用kmeans获得最终的聚类点。

3.算法实验结果

将基于蜣螂优化的Kmeans算法用于图像的分割实验。对于图像,选取10%的像素点作为聚类候选点。

对于彩色图像的聚类效果如下图所示:

在这里插入图片描述

收敛曲线:

在这里插入图片描述

4.Matlab代码

http://www.lryc.cn/news/13402.html

相关文章:

  • 第二章 Kafka设计原理详解
  • 《NFL橄榄球》:费城老鹰·橄榄1号位
  • 【人工智能AI】四、NoSQL进阶《NoSQL 企业级基础入门与进阶实战》
  • K8S 部署 Jenkins
  • 【人工智能AI】五、NoSQL 应用实践《NoSQL 企业级基础入门与进阶实战》
  • Java爬虫系列 - 爬虫补充内容+ElasticSearch展示数据
  • Typora常用快捷键
  • 开学季好用电容笔有哪些?好用实惠的电容笔推荐
  • C++_复习Recording
  • 【java】Spring Cloud --Spring Cloud 的核心组件
  • 【C++】RBTree——红黑树
  • 【5G RRC】5G系统消息SIB2介绍
  • 自托管提醒平台Noted Reminders
  • LockSupport常用方法源码分析
  • Mybatis Notes
  • MySQL 10:MySQL事务
  • 软件设计(十三)-原码、反码、补码、移码
  • 5.4 BGP地址聚合
  • 华为OD机试 - 数列还原(Python) | 机试题算法思路 【2023】
  • 华为OD机试题 - 新工号系统(JavaScript)| 代码+思路+重要知识点
  • Java-算法竞赛中常用的Java API之大数类
  • 了解Nginx,这一篇就够了
  • k8s删除pod或deployment
  • Visual Studio 2022: 增加对虚幻引擎的支持
  • 【Python】以邮件的方式定时发送一天的股票分析报告
  • mybatis条件构造器(二)
  • C++【类与对象】
  • 假设检验选择统计量重点-----正态总体参数的假设检验
  • 华为OD机试 - 通信误码(Python) | 机试题算法思路 【2023】
  • 设计模式之装饰者模式