【图像分割】模糊聚类算法FCM图像分割【含Matlab源码 084期】

news/2024/10/29 0:21:59/

⛄一、模糊聚类算法FCM简介

1 前言
图像分割是图像进行后续分析处理的基础,它将图像分成不同特征部分并获得所需目标,广泛应用于诸多领域.彩色多目标图像具有更为丰富的图像信息,目标色彩较多,且同一色彩的目标有时具有不连续性,图像分割方法中比较常见的有阈值法、边缘检测法以及边界跟踪法等,这类方法并不能取得有效的分割.近年来不少学者用聚类算法对图像进行分割,并取得了一定成果.

随着模糊理论的出现,模糊C均值聚类(FCM)分割算法由于其高效简捷得到了广泛应用.它能够将所需分割图像的信息进行很好的保留,但FCM聚类会出现局部最优、对噪声和孤立点敏感等.基于此,国内外学者提出了许多FCM改进算法和相关图像处理方法.许超结合粒子群算法和FCM进行图像分割,能够实现彩色图像的准确分割,比FCM分割结果更好.胡学刚等人针对FCM聚类的不足,采用区域分裂合并法实现了彩色图像的自适应分割,取得了良好的分割结果,并提高了抗噪性能.邱磊等人将图像在HIS颜色空间采用邻域均值进行FCM聚类,实现了噪声图像的处理.邓廷权等人将模糊Histon直方图用于模糊C聚类中实现了图像的自适应模糊C均值聚类(FCM)算法。

2 模糊C均值聚类(FCM)算法
FCM算法是J.C.Bezdek[6]引入的基于模糊理论的常用聚类算法,它使类内数据对象的相似度达到最大,类间数据对象的相似度达到最小.它是在传统划分C均值聚类的基础上进行的改进,根据图像像素隶属聚类中心的程度实现样本的划分,在图像分割中得到了较普遍的使用.但该算法起始聚类中心具有不确定性,图像聚类效果对其敏感,会出现局部最优现象.
FCM算法思想:对图像聚类中心进行初始化后,根据公式求解图像中各像素对聚类中心的隶属度与新的聚类中心,以使目标准则函数实现最优.
FCM算法的目标函数为:
在这里插入图片描述
FCM算法流程:
1)初始化vi,c和m;
2)根据公式(3)更新隶属度矩阵U.
3)根据公式(4)更新聚类中心.
4)不断迭代直到‖vi+1-vi‖<ε(ε>0),反之继续执行步骤2).

⛄二、部分源代码

%% 程序分享
%--------------------------------------

clear
close all
clc
%% %%%%%%%%%%%%%%%图像%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
I=imread(‘3096.jpg’);

if size(I,3) == 3
I=rgb2gray(I);
else
end
I=im2double(I);
figure;imshow(I);title(‘(a)原始图像’)
% I=I;%不加噪声
%I=imnoise(I,‘speckle’,deta_2);
% I=imnoise(I,‘salt & pepper’,0.05); %加噪图
% I=imnoise(I,‘gaussian’,0,0.01); % 加高斯噪声
figure;imshow(I);title(‘(b)加噪图像’);
imwrite(I,‘2.jpg’);
[m,n]=size(I);
%k 聚类数目
k=2;
% k=3;

I4 = I(😃; %% 将图像灰度按列排列
%% ------------------------ fcm算法------------------------
fcm_spatial_mean_label=zeros(m*n,1);
t=cputime;
tic;
[O2, U2, obj_fcn2] = fcm(I4, k);
toc;
time_fcm_spatial_mean=cputime-t;
%% 最大隶属度原则
maxU2 = max(U2); %隶属度最大
for j=1:k
index = find(U2(j, 😃 == maxU2); %隶属度最大对应的像素位置
fcm_spatial_mean_label(index) = j;
end
labels2=reshape(fcm_spatial_mean_label,[m n]);
labels2=uint16(labels2);

%% 显示聚类分割图
labels2(find(labels21))=0;
labels2(find(labels2
2))=255;
labels2(find(labels23))=180;
labels2(find(labels2
4))=100;
labels2=uint8(labels2);
figure;imshow(labels2,[]);title(‘©聚类分割图’);
imwrite(labels2,‘3.1.tiff’,‘tiff’,‘Resolution’,300);%输出结果,保存为tif图片

⛄三、运行结果

在这里插入图片描述
在这里插入图片描述

⛄四、matlab版本及参考文献

1 matlab版本
2014a

2 参考文献
[1]陈浩,方勇,朱大洲,王成,陈子龙.基于蚁群算法的玉米植株热红外图像边缘检测[J].农机化研究. 2015,37(06)

3 备注
简介此部分摘自互联网,仅供参考,若侵权,联系删除


http://www.ppmy.cn/news/4813.html

相关文章

jekins集成部署

jekins集成部署 1.jekins简介 2.Jenkins部署环境 3. jekins安装 4.配置jekins启动和停止脚本 5.插件安装 5.1.安装maven插件安装 5.2 安装gitee插件 5.3 安装Publish Over SSH插件 5.4 安装 事件机制插件 6.任务构建 6.1 构建任务 6.2 配置giteeApi令牌 6.3 配置gitee源码地址 …

高数一复习(更新中)

文章目录前言正文等价无穷小常用积分公式两个重要极限求极限的几个方法1.直接求2.夹逼定理3.转化为定积分求解4.洛必达法则积分的几个方法1.换元2.倒代3.分部积分4.有理化5.定积分的技巧定积分的应用1.弧长公式2.旋转体的体积3.旋转体的侧面积4.极坐标下图形的面积5.转动惯量一…

成端/接续功能使用说明

在nVisual系统中&#xff0c;接续/成端功能可以高效、准确、清晰的查看熔纤盒内的光纤连接情况。今天小编来给大家介绍一下成端和接续功能的使用。 一、成端 1. 功能入口 成端功能的入口有两种方式&#xff0c;第一个是鼠标右击选中线缆&#xff0c;出现连线右键菜单&#xf…

统计学习方法 李航 课后习题答案 第二版 机器学习

李航《统计学习方法》课后习题答案&#xff08;第2版&#xff09; &#x1f680;&#x1f680;&#x1f680;【李航课后习题解答书中疑点推导算法代码实现可私聊耐心解答(48小时内回复)&#xff0c;包会&#xff01;&#xff01;】 也可进入我的个人主页查看分类专栏里的《统计…

文件权限 与 chmod 命令

文件权限 # 创建一个文件和文件夹 $ touch A.txt $ mkdir dic# 通过 ll 命令查看详细信息 $ ll -rw-r--r-- 1 root root 0 Oct 14 13:33 A.txt drwxr-xr-x 2 root root 4096 Oct 14 13:33 dic注意文件与文件夹的第一段信息&#xff1a; -rw-r--r-- drwxr-xr-x这其中就包含…

2G/3G LAC与4G/5G TAC的协同优化

【摘 要】为规避移动通信网络中往往存在的4G TAC和2G/3G LAC不一致及插花的不合理现象,以及部分TAC边界基站下的终端跨TAC重选和切换较多的情况,需要开展TAC/LAC的协同优化工作。根据网络结构、TAC/LAC配置及业务流程,主要从移动终端在空闲态及被叫状态下,处于TAC/LAC的异…

【MybatisPlus】最全面的MybatisPlus通关教程

前言 本文为最全面的MybatisPlus通关教程相关介绍&#xff0c;下边将对MyBatisPlus概述&#xff0c;MyBatisPlus快速入门&#xff0c;CRUD扩展&#xff08;包括&#xff1a;插入操作、主键生成策略、更新操作&#xff0c;自动填充&#xff0c;乐观锁&#xff0c;查询操作&#…

新冠的经历

本篇博文始于2022年12月10日&#xff0c;记录一下我的新冠经历 第一天&#xff1a;12月9日早上起来喉咙痛&#xff0c;吞咽水比较费劲&#xff0c;房东大哥说自己感冒了&#xff0c;没去上班&#xff0c;屋内都是药和卫生纸&#xff0c;询问他是否阳性&#xff0c;一直不回我&a…