数字图像处理实验十二迭代法阈值分割

利用迭代法对图像进行阈值分割。

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('迭代法阈值分割图像')

效果图展示

数字图像处理实验十二迭代法阈值分割_第1张图片

 

你可能感兴趣的:(Matlab数字图像处理实验,图像处理,Matlab,数字图像处理实验)