数字图像处理实验十二迭代法阈值分割
利用迭代法对图像进行阈值分割。
clear;
clc;
%----------------------------图像的灰度化处理-------------------------------
JPG=imread('1.jpg');
JPG=rgb2gray(JPG);
figure();
imshow(JPG);title('原始图像')
%-----------------------------迭代法阈值分割--------------------------------
T=mean2(JPG); %取均值作为初始阈值
i=0; %记录迭代次数
% while循环进行迭代
while 1
i=i+1; %记录迭代次数
R1=find(JPG<=T); %小于阈值的部分
R2=find(JPG>T); %大于阈值的部分
T1=(mean(JPG(R1))+mean(JPG(R2)))/2; %计算分割后两部分的阈值均值的均值
if abs(T1-T)<0.1 %两个平均灰度基本无差别时退出
T=T1;
break;
end
T=T1; %如果差别较大,则将分割后的均值作为新的阈值再次进行运算
end
JPG(R1)=0; %将小于阈值的部分赋值为0
JPG(R2)=1; %将大于阈值的部分赋值为1 这两步是将图像转换成二值图像
figure();
imshow(JPG,[]);title('迭代法阈值分割图像')
效果图展示
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了