数字图像处理之matlab实验(六):图像分割

在图像处理领域,我们更关注的是一些关于目标的分析或者描述信息,比如图片里面是否有猫,以及是什么品种的猫?在在做这一步之前,我们需要先把图像中的猫分割出来。可以说图像分割是最基础也是最重要的一步操作,会影响后面的识别工作的准确性。

图像分割就是将图像分成前景(目标)图像和背景图像。以上图为例,我们想要分割出猫,就需要找到猫的边界。因此图像分割也可以用一些边缘检测算法实现。

1、基于双峰阈值法图像分割

这类算法仅仅适用于部分容易找到阈值的情况。

clear,clc,close all;
Image=rgb2gray(imread('lotus1.jpg'));
subplot(221),imshow(Image),title('原始图像');
%imhist(Image);
hist1=imhist(Image);
hist2=hist1;
iter=0;
while 1
    [is,peak]=Bimodal(hist1);
    if is==0
        hist2(1)=(hist1(1)*2+hist1(2))/3;
        for j=2:255
            hist2(j)=(hist1(j-1)+hist1(j)+hist1(j+1))/3;
        end
        hist2(256)=(hist1(255)+hist1(256)*2)/3;
        hist1=hist2;
        iter=iter+1;
        if iter>1000
            break;
        end
    else
        break;
    end
end

[trough,pos]=min(hist1(peak(1):peak(2)));
thresh=pos+peak(1);
subplot(222),stem(1:256,hist1,'Marker','none');
hold on
stem([thresh,thresh],[0,trough],'Linewidth',2);
hold off
result=zeros(size(Image));
result(Image>thresh)=1;
subplot(223),imshow(result),title('基于双峰直方图的阈值化');
imwrite(result,'bilotus1.jpg'); 
function [is,peak]=Bimodal(histgram)
    count=0;
    for j=2:255
        if histgram(j-1)<histgram(j) && histgram(j+1)<histgram(j)
            count=count+1;
            peak(count)=j;
            if count>2 
                is=0;
                return;
            end
        end
    end
    if count==2
        is=1;
    else
        is=0;
    end
end


2、OSTU法二值化图像

Image=rgb2gray(imread('lotus1.jpg'));
subplot(121),imshow(Image),title('原始图像');
T=graythresh(Image);
result=im2bw(Image,T);
subplot(122),imshow(result),title('OTSU方法二值化图像 ');

 3、基于边缘的图像分割

请参考图像锐化部分的边缘提取数字图像处理之matlab实验(三):空间滤波器_苗妮的博客-CSDN博客

4、基于区域生长的图像分割

clear,clc,close all;
Image=im2double(imread('lotus1.jpg'));
[height,width,channel]=size(Image);
if channel==3
    Image=rgb2gray(Image);
end
figure,imshow(Image);
% Image=[1 0 4 6 5 1;1 0 4 6 6 2;0 1 5 5 5 1;0 0 5 6 5 0;0 0 1 6 0 1;1 0 1 2 1 1];
% [height,width,channel]=size(Image);
% figure,imshow(Image);
[seedx,seedy,button] = ginput(1);
seedx=round(seedx);
seedy=round(seedy);
region=zeros(height,width);
region(seedy,seedx)=1;
region_mean=Image(seedy,seedx);
region_num=1;
flag=zeros(height,width);
flag(seedy,seedx)=1;
neighbor=[-1 -1;-1 0;-1 1;0 -1;0 1;1 -1;1 0;1 1];
for k=1:8
    y=seedy+neighbor(k,1);
    x=seedx+neighbor(k,2);
    waiting(k,:)=[y,x];
    flag(y,x)=2;
end

pos=1;
len=length(waiting);
while pos<len
    len=length(waiting);
    current=waiting(pos,:);
    pos=pos+1;
    pixel=Image(current(1),current(2));
    pdist=abs(pixel-region_mean);
    if pdist<40/255 
        region(current(1),current(2))=1;
        region_mean=region_mean*region_num+pixel;
        region_num=region_num+1;
        region_mean=region_mean/region_num;
        for k=1:8   
            newpoint=current+neighbor(k,:);
            if newpoint(1)>0 && newpoint(1)<=height && newpoint(2)>0 && newpoint(2)<width && flag(newpoint(1),newpoint(2))==0
                waiting(end+1,:)=newpoint;
                flag(newpoint(1),newpoint(2))=2;
            end
        end        
    end
end
figure,imshow(region),title('区域生长');
imwrite(region,'regiongrow.jpg');
    

  • 12
    点赞
  • 86
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用Matlab的Image Processing Toolbox中的kmeans函数进行图像聚类分割,具体步骤如下: 1. 读取图像 2. 将图像转换为灰度图像 3. 将灰度图像矩阵转换为向量 4. 调用kmeans函数,设置聚类数和迭代次数等参数 5. 将聚类结果矩阵重塑为图像矩阵 6. 显示聚类结果图像并进行调整和优化 使用kmeans聚类算法进行图像分割,可以对图像进行快速准确的分割,使得图像处理更加高效、精确、可靠。 ### 回答2: k-means clustering是数字图像处理中使用的一种常见算法,该算法能够对图像进行聚类、分割和分析。在matlab数字图像处理实验中,k-means clustering可以用来将彩色图像分割成若干个类别,每个类别代表着图像中的一种颜色或一种纹理。在这个过程中,k-means clustering会使用聚类中心来表示每个类别,聚类中心是类别的中心点,能够反映类别的特征。在分割结束后,我们可以将每个像素点所在的类别赋予它一个颜色,从而得到了一幅分割后的图像。 在对图像进行k-means clustering分割时,我们首先需要将图像转化为向量形式,即将图像中的每个像素都表示成一个向量,并将这些向量组成一个矩阵。然后,我们通过对向量之间的距离度量来计算聚类中心,即通过将向量分成k个类别并计算每个类别的中心点来确定聚类中心。接着,我们使用聚类中心来进行分割,将图像中的每个像素都与聚类中心进行比较并将其分配到最接近的类别中。分割结束后,我们还可以使用一些可视化的方法来显示分割后的图像,例如各个类别的中心点、每个像素所属的类别等。 k-means clustering 在图像分割中具有很大的优势,它不仅可以对图像进行颜色分割,还能够对图像中的其他特征进行分割,例如纹理、形状等。此外,该算法既简单又有效,能够在较短的时间内完成图像的分割和聚类。因此,在matlab数字图像处理实验中,k-means clustering是一种非常实用的算法,能够为我们分析和处理图像提供有力的支持。 ### 回答3: K-Means聚类算法是图像分割中常用的算法,该算法能够将图像分成数个不同的类别,从而实现对图像分割的目的。Matlab是一个强大的数字图像处理工具,也是一个非常好的实验平台,我们可以使用Matlab来实现K-Means聚类算法对图像进行分割。 首先需要准备一张需要分割的图像,并将图像转换为灰度图像。然后使用Matlab自带的函数imread()对图像进行读取,使用imresize()函数进行图像大小的调整。接下来,我们可以使用imhist()函数查看图像的灰度直方图,以便对图像的特征有更加全面的了解。 接下来,使用K-Means算法进行图像分割Matlab自带了一个kmeans()函数,该函数可以很方便的使用K-Means算法对图像进行分割。使用kmeans()函数需要给函数传递三个参数,分别是需要分割的图像、分割的类别数和最大迭代次数。分割的类别数和最大迭代次数需要进行多次实验调整选择,适合的类别数和最大迭代次数能够得到更好的图像分割效果。 最后,我们可以使用Matlab自带的imshow()函数查看图像分割的结果,为了方便比较,我们需要将图像分割前和分割后的图像进行比对。如果图像分割效果不理想,我们可以通过参数调整或改变算法来进行优化,比如可以使用其他聚类算法、改变聚类的特征参数或对图像进行其他处理等。 总之,K-Means聚类算法是图像分割中常用的算法之一,使用Matlab作为实验平台可以很方便的进行图像处理和算法实现。了解了算法流程后,我们可以通过多次实验对参数进行调整,以得到比较好的图像分割效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值