热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

基于MATLAB的数字图像分割的研究与实现

1绪论1.1图像分割的研究背景在一幅目标图像下,人们往往只是关注其中的一个或者几个目标,而这些目标必然会占据一定的区域,并且与周围其他目标

1 绪论

1.1 图像分割的研究背景

在一幅目标图像下,人们往往只是关注其中的一个或者几个目标,而这些目标必然会占据一定的区域,并且与周围其他目标或背景在一些特征上会有相应的差别。但是,很多时候这些差别会非常的细微,以至于人眼很难发觉,这就需要用一定的技术对图片做一些处理。而计算机图像处理技术的发展,很好地解决了这一难题,使得人们可以利用计算机技术来协助理这些信息,例如指纹识别、车牌识别以及医学影像的鉴别操作等方向。

图像分割是图像识别的基础,其通过一些必要的算法把图像中有意义的部分或特征提取出来,将图像分为若干有意义的区域,并形成数字特征,这些区域对应图像中的不同目标。这些具有某种特征的单元成为图像的基元,这种经过处理的基元更容易被快速处理。

目前,数以千计的研究文献和文章提出了许许多多的图像分割算法,不同种类的图像、不同的应用要求和应用领域所需要提取出的图像特征是不相同的,所以并不存在普遍适用的最优方法,只能根据图像特征选择与值相适应的方法。

1.2 图像分割的基本原理

图像分割是根据图像的直方图和结构特性或者一些具体的应用需求将图像划分成两个或多个互不相交的子区域的过程,这些子区域是在特定意义下的具有相同属性的像素的连通集合。例如,一幅图像中不同目标物体所占的图像区域、背景所占的背景区域等都属于这样的连通集合概念。

对图像分割的定义有多种不同的解释,人们普遍接受的是通过集合定义的图像分割。用集合R表示整个图像区域,那么对整个图像的分割可以等价于将集合R分成n个满足以下准则的区域:

v2-266181c5256c2d204bd5cf803ba5fbd9_b.jpg


v2-65ad24fdaa975446fbd4852adea46e8b_b.jpg


v2-8957ff61ed0d7d4a8380b1533b2a408f_b.jpg


v2-5a849a93680859735b3406c1e73aaa2d_b.jpg

false;

v2-9a1ff5ad6e71ea816cce88a91f196024_b.jpg

true。

目前提出的图像分割方法很多,在此分为三种不同的途径对其进行分类:

  1. 以物体的的边界为对象进行分割;
  2. 先检测边缘像素,再将边缘像素连接起来形成分割;
  3. 以区域为对象进行分割,根据图像的灰度、色彩、变换关系或组织结构等方面的特征相似性来划分图像的子区域并将各像素划分到特定区域。

上述这些方法是互补的,不同的场合使用不同的方法,或者综合各个方法已达到最佳的分割效果。



3 阈值化分割

阈值分割的基本原理为:利用一定的方法,设定不同的阈值,把图像的像素点分到若干不同的区域中。阈值分割是一种比较简单有效的图像分割方法,该方法利用一个或多个阈值将图像像素分为不同的灰度级分,将属于同一灰度级的像素划分为相同的区域。根据求阈值的不同,可以分为双峰法、迭代法以及最大类间方差法。

3.1 双峰法

双峰法即人工选择法,通过人眼对图像直方图的观察,选出合适的阈值。

3.1.1 数学推导

假定图像由具有不同灰度级的目标背景组成,图像的灰度分布曲线可以近似地认为有两个正态分布函数

v2-6d9a907c5178e46848d7ef4b4f97d5d0_b.jpg

v2-fa24f73fc9810b987ed547e97d54c69e_b.jpg

叠加而成,则图像会出现具有双峰的分布特性的直方图,该特性可以用图3.1表示。


v2-1e1b5f1f11778369cb85474ea9ef4c6f_b.jpg


图3.1 具有双峰分布的直方图

如图3-1,选择双峰直方图的波谷处,设其灰度级为P,则可以将图像分为两部分,即可以表示为:


v2-bc5fc3ec9c24a3c67c5b0d3e0917e847_b.jpg


其中,P为分割阈值,结果图像的灰度级取

v2-7ca68d80f9ff607c7cd1c851cbdfacc8_b.jpg

若为多个阈值,则:


v2-fe84efcda4e16893eef20677abc82074_b.jpg


3.1.2 双峰法图像分割示例

利用双峰法进行图像分割,首先要查看图像直方图的分布情况,即在MATLAB中执行下述程序,来观察所需分割图像的直方图:

clear all

I=imread('细菌.jpg');

figure(1);

imshow(I);

title('原始图像');

figure(2);

imhist(I);

title('直方图');

axis([0 255 0 2000]);

执行结果如图3.2所示。


v2-3455ddd88474f9686cc528353b78756f_b.jpg

v2-df4ab2b93671c281cf13f6dfbf1484aa_b.jpg


图3.2 原图与直方图

观察上述直方图可以选择阈值为30,执行下述分割程序:

th=30;

J=im2bw(I,th/255);

figure(3);

imshow(J);

title('分割结果');

分割结果如下图3.3所示。


v2-424b80e9631c89098f9e2ef2fddb9d13_b.jpg


图3.3 双峰法分割结果

3.2 自动选择法

自动选择法通常根据图像直方图所呈现出的特性来分析图像灰度值的分布情况。

3.2.1 自动选择法推导过程

1 迭代法

双峰发对于目标区域和背景区域像素的分布区域有明显区别是容易使用,对于不明显的图像阈值选择需要进行改进,而迭代法正式基于这种要求产生的。

迭代法可以利用一定的算法原理来完成阈值的自动选取操作,并能根据所选取的阈值进行分割操作,其具体实施步骤如下:

  1. 选择一个初始阈值P,可利用图像像素的最大灰度和最小灰度来选择;
  2. 利用选择的阈值P对图像进行分割分为大于P和小于P两部分;
  3. 计算两个区域的灰度均值

v2-4bb3421c4d99afc50511c0868880db3e_b.jpg

;

  1. 计算新阈值

v2-32c1c534751c0da3741bae75fa405f93_b.jpg

2 最大类间方差法

最大类间方差法的计算方法为:

根据灰度级,确定阈值T,就可以把一幅数字图像

v2-0b6005253e9df19b38b43732c3abc009_b.jpg

的像素点分为两个类中,其中图像灰度的最小值、最大值分别表示为

v2-a87eeebd4d0c820231a7722fa38ef418_b.jpg

则可以把图像表示为:


v2-f663766980f1ce0e8c1a04661eb77ff3_b.jpg


图像总的像素为:

v2-daf34b7865b8c7fbd104fa7f8baabe71_b.jpg

,则各灰度出现的概率为,

v2-067c339fb27ae7ead8c86c7a7357aa18_b.jpg


假设两个区域分别为A,B,则区域A出现的概率为:

v2-0b6f2cbb6995f9998b12d5e90a8ef2c1_b.jpg

,

均值为:

v2-aac192e9fa5330f20231d036e0cdeed7_b.jpg


则区域B出现的概率为:

v2-d700fa7cc1961836c765905dc865b5c2_b.jpg


均值为:

v2-c6e2389655c9a97447772bfd0519f34e_b.jpg


图像

v2-c778e902471a00620b3a2f9c61cf1422_b.jpg

的均值为:

v2-03875d13ac3ba9c227449a06f7632650_b.jpg


两个区域的方差为 :

v2-3c150da60c96366f578cfba826dc0e20_b.jpg


最大类间方差法是把两类的类间方差作为阈值的选择标准,使得类间方差

v2-612ab98f40c008c9d035240fddb2d9f7_b.jpg

最大的T则为最佳阈值。

3.2.2 迭代法图像分割

使用MATLAB利用迭代法进行图像分割操作时,根据之前原理的描述,需要编写以下程序代码:

clear all

I=imread('细菌.jpg');

tmin=min(I(:));

tmax=max(I(:));

th=(tmin+tmax)/2;

ok=true;

while ok

g1=I>=th;

g2=I

ok=abs(th-thnew)>=1;

th=thnew;

end

th=floor(th);

J=im2bw(I,th/255);

subplot(1,2,1);

imshow(I);

title('原始图像');

subplot(1,2,2);

str=['迭代分割阈值:阈值Th=',num2str(th)];

imshow(J);

title(str);

将以上程序输入MATLAB命令窗口,得到如下图3.4的分割结果。


v2-eb421fc6ebc8b26476134f1b615e333f_b.jpg


图3.4 迭代法分割结果

3.2.3 最大类间方差法图像分割

MATLAB的库函数中直接提供了最大类间方差法的阈值分割grayhresh函数,语法格式为:level=graythesh(I)

使用MATLAB进行图像分割时,需要的程序如下:

clear all

I=imread('细菌.jpg')

th=graythresh(I);

J=im2bw(I,th);

subplot(1,2,1);

imshow(I);

title('原始图像');

subplot(1,2,2);

str=['最大类间方差法分割结果:TH=',num2str(th)];

imshow(J);

title(str);

程序执行后的分割结果如下图3.5所示。


v2-0d897d0c490c2552727f58c4773666bc_b.jpg


图3.5 最大类间方差法图像分割结果

4 区域化分割

4.1 区域生长分割算法

4.1.1 区域生长法简介

区域生长是从图片的一个像素出发,即选取一个种子像素,比较与之相邻的像素之间的相似性,将与种子像素在灰度、边缘、纹理等特征具有相似属性的像素归并到同一个区域,然后再将这些像素点作为新的种子像素继续上述归并过程,直到查找不到满足条件的像素为止,从而完成对一幅图片的分割操作。

区域生长算法具体描述如下:

  1. 选取图像目标区域一点作为种子像素点

v2-42ee29bf8a1f1ddf00e5012a3fabe3f1_b.jpg

;

v2-d75652860d45d83435d2a7213b0c1f0a_b.jpg

为中心,与

v2-d75652860d45d83435d2a7213b0c1f0a_b.jpg

的邻域像素

v2-4456858c29369109aa879ecfc5df85bd_b.jpg

进行比较,如果

v2-3b1e0e70ecdb49069819c16fb7074171_b.jpg

满足选定的生长准则,则将

v2-8eec9f917563c9ecdb3a2a90ef9920dc_b.jpg

v2-d75652860d45d83435d2a7213b0c1f0a_b.jpg

合并;

  1. 再将归并的像素点

v2-1a989cd9148a78d7c780d9f02da48bf3_b.jpg

作为新的种子像素点

v2-d75652860d45d83435d2a7213b0c1f0a_b.jpg

,继续步骤(2)的操作;

  1. 当满足区域生长的停止条件时,结束操作,完成分割算法。

其中,生长准则是评价种子像素与其邻域像素点的相似程度的判断准则;根据设定不同的阈值来确定停止条件,停止条件的选择对分割结果的精确度有至关紧要的作用,在利用区域生长法进行图像的分割时,要根据具体的图像特征来选择合适的生长停止条件。

利用图形形象的表示区域生长法原理如下4.1所示。


v2-47b2fad9d5b8b6bb14ce7e11d2faf396_b.jpg


a) 原始图像和种子点 b) 阈值T=1 c) 阈值T=2

图4.1 区域生长

4.1.2 区域生长法的MATLAB程序与分割操作

1 MATLAB程序

(1)先编写区域生长法的算法程序,并保存在MATLAB的m文件中,程序如下:

function Yout=regiongrow(I,seed,th_mean)

[M,N]=size(I);

L=size(seed);

Yout=zeros(M,N);

for i=1:L

Yout(seed(i,1),seed(i,2))=1;

end

for i=1:L

sum(i)=I(seed(i,1),seed(i,2));

end

seed_mean=mean(sum);

ok=true;

s_star=1;

s_end=L;

while ok

ok=false;

for i=s_star:s_end

x=seed(i,1);

y=seed(i,2);

if x>2&&(x+1)2&&(y+1)

for u=-1:1

for v=-1:1

if Yout(x&#43;u,y&#43;v)&#61;&#61;0&abs(I(x&#43;u,y&#43;v)-seed_mean)<&#61;th_mean

seed&#61;[seed;[x&#43;u,y&#43;v]];

end

end

end

end

end

s_star&#61;s_end&#43;1;

L&#61;size(seed);

s_end&#61;L;

end

&#xff08;2&#xff09;对上述m文件保存为regiongrow.m格式&#xff0c;编写区域生长的主程序并调用上述regiongrow算法&#xff1a;

clear all

I&#61;imread(&#39;细菌.jpg&#39;);

figure(1);

imshow(I);

title(&#39;原始图像&#39;);

I&#61;double(I);

[y1,x1]&#61;getpts;

x1&#61;round(x1);

y1&#61;round(y1);

seed&#61;[x1,y1];

Yout&#61;regiongrow(I,seed,th_mean);

figure(2);

imshow(Yout);

title(&#39;区域生长分割&#39;);

2 分割结果图

执行程序时&#xff0c;首先在figure1窗口选择需要的种子点选择&#xff0c;在此选择中间的大个细菌作为示例&#xff0c;其中选择不同的阈值th_mean会得到不同的分割结果&#xff0c;当th_mean&#61;40时分割结果如图4.2所示。


v2-e089defdae9d2cb34f34e0f898143588_b.jpg

v2-c8bd9d3f11a165fb06fd27dfd029fb15_b.jpg


图4.2 区域生长法分割效果&#xff08;th_mean&#61;40&#xff09;

当th_mean&#61;70时&#xff0c;得到的分割结果如图4.3所示。


v2-fb7a869e070d42b3d2a8cbb1de8fce55_b.jpg


图4.3 区域生长法分割效果&#xff08;th_mean&#61;70&#xff09;

由图4.2和图4.3可以发现&#xff0c;当选择th_mean&#61;70时&#xff0c;分割效果已经很好&#xff0c;当选择更大的th_mean时&#xff0c;会归并更多的像素&#xff0c;即有可能将背景像素归到目标区域中&#xff0c;进而影响分割准确性&#xff0c;所以&#xff0c;要根据图片特点选择合适的th_mean值。

4.2 分裂合并分割算法

4.2.1 分裂合并分割算法简介

分裂合并分割算法的原理是根据图像数据的四叉树的层次结构来将图像划分成几个不相交的区域&#xff0c;然后从这个结构中的任何一个区域开始&#xff0c;依照一定的准则来分裂、合并这些区域。当一个区域中的数据特征不满足这一准则时&#xff0c;则对这一区域继续进行分裂操作&#xff0c;直至相邻的区域之间满足一定的特征时&#xff0c;分裂结束&#xff0c;进行合并。

分裂合并分割算法中经常使用的方法就是四叉树分解法&#xff0c;令R表示整个图像区域&#xff0c;如果

v2-1161bb860f751bcb4fd9bccc2bec5191_b.jpg

&#xff0c;则将图像分成四个区域&#xff0c;如果有任何一个区域依然有

v2-1161bb860f751bcb4fd9bccc2bec5191_b.jpg

&#xff0c;怎讲这个继续分割为四个区域&#xff0c;以此类推直到

v2-f2ef6ab6e209ba002acaf103e0604543_b.jpg

为单个像素。四叉树分解法可以用下图4.4的示意图表示。


v2-d21b376329f6ed28969d0123c586ae8f_b.jpg


a) 图像分割示意图 b) 四叉树表示

图4.4 四叉树分解示意图

如图4.5所示&#xff0c;假设图中灰色区域为我们所需要的目标区域&#xff0c;白色为背景区域。对整个图像

v2-1161bb860f751bcb4fd9bccc2bec5191_b.jpg

&#xff0c;令

v2-7aa00fd82b74fc62dbfe04067a509958_b.jpg

表示该区域中所有像素均具有相同的灰度值。所以根据以上条件先将图(a)分割成四个区域&#xff0c;此时右上角的区域满足

v2-7aa00fd82b74fc62dbfe04067a509958_b.jpg

&#xff0c;所以不再进行分割&#xff0c;而其他区域继续进行分割操作&#xff0c;直至分割的每个子区域均满足条件&#xff0c;则分裂停止&#xff0c;进行合并。


v2-6ed864963c66eb892974cbe9d04b67d5_b.jpg


(a) 原图像 (b) 分裂过程1 (c) 分裂过程2 (d) 分裂过程3

图4.5 区域分裂与合并分割法图解

根据四叉树分解示意图&#xff0c;MATLAB中提供了三种函数来实现这一规则。具体操作步骤是&#xff0c;首先将图像分成四个小区域&#xff0c;然后根据一定的准则判断各个区域是否具有特定的相似性&#xff0c;不满足则进行进一步的分裂&#xff0c;直至分裂的每一小块都达到一定的相似准则&#xff0c;再对各个区域进行合并。

qtdecomp函数用于对图像进行四叉树分解&#xff1b;

qtgeblk函数用于经过四叉树分解后的各个区域的图像信息&#xff1b;

qtsetblk函数用于设定分解区域的灰度值。

4.2.2 分裂合并法的MATLAB程序与分割操作

对数字图像进行分裂合并分割的MATLAB程序为&#xff1a;

clear all

I&#61;imread(&#39;细菌.jpg&#39;);

S&#61;qtdecomp(I,.2);

blocks&#61;repmat(uint8(0),size(S));

for dim&#61;[512 256 128 64 32 16 8 4 2 1];

numblocks&#61;length(find(S&#61;&#61;dim));

if(numblocks>0)

values&#61;repmat(uint8(1),[dim dim numblocks]);

values(2:dim,2:dim,:)&#61;0;

blocks&#61;qtsetblk(blocks,S,dim,values);

end

end

figure(1);

subplot(1,2,1);

imshow(I);

title(&#39;原始图像&#39;);

subplot(1,2,2);

imshow(blocks,[]);

title(&#39;分解图像&#39;);

对细菌图像进行分割后的结果图为图4.6所示。


v2-553a1833985cc101987ae66ffb54099c_b.jpg


图4.6 细菌图像的四叉树分解

5 图像分割算法的评价

5.1 图像分割算法评价概述

尽管已经有了很多种分割算法&#xff0c;而且该技术也在不断地发展中&#xff0c;但是迄今为止仍然还没有一种通用的分割算法&#xff0c;绝大部分分割算法通常有一定的使用围。而对于某个具体实际图像&#xff0c;为了得到满意的分割结果&#xff0c;通常会面临一个如何选择合适的分割算法的问题&#xff0c;特别是对分割算法不是很了解的情况下&#xff0c;这时就需要参考分割算法的一些性能指标来进行选择。这就是分割算法中的评价问题。尽管很多文献与著作在分割算法的评价方面已有了较深入的研究&#xff0c;但是迄今为止还没有一个通用的客观评价标准&#xff0c;在这个方面就需要我们做出进一步的努力。在做图像处理时要求我们根据不同的要求选择合适的分割算法&#xff0c;因此对不同分割算法作一个比较客观的评价是必需的。

5.2 图像分割算法评价方法和要求

图像分割算法的评价可以有一下这些情况&#xff1a;

&#xff08;1&#xff09;性能刻划。即同一分割算法在不同的图像情况下&#xff0c;分割的性能比较。

&#xff08;2&#xff09;性能比较。比较不同的分割算法在对同一个图像进行分割时&#xff0c;分割性能的比较。

对分割评价算法的一般要求包括&#xff1a;评价算法的通用性、评价算法的复杂性、可靠性&#xff0c;是否需要参考图和是否需要人工参考等。一般通过分析和实验两种方式对分割算法进行客观评价。所以一个客观的评价方法可分为分析与实验方法两类。

1 分析法

分析法对图像的原理和性能进行直接分析。该算法的原则是指所采用的分析方法和理论,经常采用先进的理论方法将得到更精确的结果。虽然分析方法能避免某些因素,但缺乏分割结果的支持,具有较大的局限性&#xff0c;通过分析分割结果的实际评价分割算法具有实际意义。分析方法通常提供辅助信息,它很少单独使用。

2 实验评价方法

实验法是比较不同算法的分割结果&#xff0c;对分割结果图像进行评价的。在实际应用也是经常使用中这种评价方法。实验方法是对测试图像分割结果进行评估&#xff0c;实验方法所提出的评价方法,一般可分为优化方法和偏差的方法。优化方法是基于一般人的一些视觉图像特征为依据来评估分割效果;偏差的方法通常需要提供一个理想的分割图像作为比较标准&#xff0c;根据计算实和理想分割图像分割效果的差异,但可供比较的形象往往难以统一样本。

5.3 本文算法分析与评价

本文中介绍了两种不同的分割算法&#xff0c;分别为阈值化分割和区域化分割&#xff0c;其中阈值分割算法又有三种不同的求阈值方法分别为双峰法、迭代法和最大类间法&#xff1b;区域化分割又包括区域生长法和分裂合并法。

其中各自的适用围如下&#xff1a;

&#xff08;1&#xff09;双峰阈值算法适合直方图呈现明显双峰特性的图像&#xff0c;在进行图像分割之前先进行一步对图像的求直方图操作&#xff0c;根据直方图所体现的特性找出谷点即为所需要的阈值&#xff0c;在直接给阈值th赋值为该谷点的值利用函数im2bw进行分割。

但是&#xff0c;很多时候图像的直方图并不能体现出明显的双峰特性&#xff0c;这时候找到的谷点值就不能很好地把目标图像分割出来&#xff0c;会把大量的目标像素归为背景或者把大量的背景元素归为目标&#xff0c;这样则会是分割的准确性下降&#xff0c;进而影响对图像下一步的处理操作。

例如对lena图像进行双峰法的阈值分割过程与结果如下&#xff1a;

先对其进行求直方图操作&#xff0c;结果如下图5.1所示。

v2-fd361be64417a77cb17c02b424c83834_b.jpg


v2-0df1a42f4ebf621497a131240e0900b5_b.jpg

图5.1 lena图像的直方图

lena的直方图特点如上&#xff0c;如果利用双峰法进行分割则需要确定阈值&#xff0c;若选择阈值th&#61;60&#xff0c;进行分割结果如图5.2所示。

v2-b759b5b221d5ba3aaf35d0e321f9a33d_b.jpg

v2-4afa23921571ef124c739502214ce3c3_b.jpg

图5.2 阈值th&#61;60分割结果 图5.3 阈值th&#61;90分割结果

若选择阈值th&#61;90&#xff0c;进行分割的结果如上图5.3所示。

由图5.2与图5.3可以看出&#xff0c;图5-3显示的当th&#61;90时的分割效果就比th&#61;60时的分割效果要好&#xff0c;但是两个不同阈值的效果都没有达到理想的分割结果&#xff0c;即未能把目标图像很好地分割出来。

可以得出结论&#xff1a;如果图像的直方图没有呈现明显的双峰特性&#xff0c;那么利用双峰法进行的分割结果就不准确&#xff0c;即双峰法适合对一些背景简单、直方图具有双峰特性的图像来进行分割。

  1. 有些时候&#xff0c;图像直方图呈现一定的双峰特性&#xff0c;但是并不能直观、准确的观察出图像的阈值特点&#xff0c;这就需要利用一定的算法实现自动选取阈值&#xff0c;迭代法就是在这个方面对双峰法的改进&#xff0c;该方法可以完成阈值的自动选取。

例如对之前lena图像进行分割&#xff0c;如果使用迭代法分割结果如下5.4所示。

v2-68b10128e8511e4f73fe01527283d472_b.jpg

图5.4 迭代法对lena图像进行分割

再对cameraman图像的分割示例&#xff1a;

首先&#xff0c;求出该图像的直方图&#xff0c;结果为图5.5所示。


v2-548165195fc447bed96d7cc7e65209db_b.jpg


图5.5 cameraman的直方图特性

如利用双峰法选择阈值th&#61;60&#xff0c;进行的分割结果如图5.6所示


v2-74b481467741ff73cd5f8ce72746403f_b.jpg

图5.6 对cameraman选择阈值为60进行分割结果

而利用迭代法进行的分割结果如图5.7所示。

v2-361edfb9346796212f0f2e574704f27e_b.jpg

图5.7 迭代法分割结果

比较图5.6与图5.7能发现迭代法分割的效果就比双峰法分割效果要更准确&#xff0c;例如&#xff0c;迭代法就把图片的下半部分很好的分割了出来。

可以得出结论&#xff1a;对于那些具有一定的双峰特性但又不是能明确观察出阈值的图像就要求我们利用迭代法来进行分割&#xff0c;即迭代法是对双峰法的改进。

  1. MATLAB中提供了一种最大类间方差阈值分割的阈值函数graythresh&#xff0c;用法为&#xff1a;th&#61;graythresh(I)&#xff0c;I可以使uint8、uint16或者是double型的图像。该分割算法能根据不同的图像调用graythresh函数来获得最佳阈值&#xff0c;选择lena图像进行示&#xff0c;结果如图5.8所示。


v2-a6bcb3766337c0b08bc13080caa58a4f_b.jpg

图5.8 最大类间方差法图像分割

对于一些不存在双峰特性的图像也能进行比较理想的分割效果&#xff0c;例如下图5.9所示图像。


v2-4a3d3bf02cd1df3b22fecdd70636ad5a_b.jpg

v2-88292c11d61fe7ac7edbab552ccf4295_b.jpg


图5.9 原图像与直方图

观察上图的直方图并不体现双峰特性&#xff0c;利用该方法进行分割结果如下图5.10所示。


v2-2b27032c99c853a65151a6e51b6af04a_b.jpg

图5.10 原始图像与分割结果

  1. 以上三种都能针对特定的图像进行目标分割&#xff0c;但是很多时候我们只需要对目标图像的一部分进行研究&#xff0c;那么就只要求我们将所需的部分分割出来&#xff0c;根据这一要求生成了区域生长算法&#xff0c;利用这种算法能根据需要自主地选择种子像素点&#xff0c;从而分割出需要的部分。例如下图5.11的示例。

v2-0ce93766f0c2a9dea2104bc3220ff02b_b.jpg

v2-6b463320f6b5f8b8087134db488396b4_b.jpg

图5.11 区域生长法分割示例

如上图的示例所示&#xff0c;该分割方法可以根据图像特点在m文件里设定graythresh函数的不同阈值&#xff0c;选取特定的种子像素点利用区域生长法找到它周围相近或者说像素差值在一定阈值的像素点&#xff0c;归并为一个区域&#xff0c;然后显示出来。

  1. 区域生长过程是从一组生长点开始&#xff0c;通过不断地接纳新像素最后得到整个目标区域。而分裂合并法是在开始时将图像分割成一系列任意不相交的区域&#xff0c;直到最后所分得的每个区域的像素都满足一定的灰度值则分裂停止&#xff0c;进行合并。该方法能对所有图片进行分割&#xff0c;但是对那些目标区域灰度值较相近的并且与背景区域灰度值有明显差别的图像能进行较好的分割。例如对cameraman和硬币图像的分割效果&#xff0c;如图5.12和5.13所示。


v2-92f890d5f496aadfb32abc4aedc2e830_b.jpg


图5.12 分裂合并法对cameraman分割示例


v2-b9a24faf6417cc15797d774880f0bd7b_b.jpg


图5.13 分裂合并法对cameraman分割示例

由图5.12与图5.13可以明显的观察到&#xff0c;当图像的目标区域像素灰度值相近时使用分裂合并分割算法进行分割的效果会比较准确&#xff0c;分割效果更接近所需结果。但对于类似cameraman类型图片时&#xff0c;即目标区域像素的灰度值分布较离散&#xff0c;不具有相似性的图片时&#xff0c;利用该算法就无法将所需目标精确地分割出来&#xff0c;分割的效果就比较粗糙。在精确性要求较高的情况下&#xff0c;该算法就不能完成要求。

6 总结

根据前几章的研究&#xff0c;本文具体概括了一下阈值化分割和区域化分割的基本理论和实验。其中&#xff0c;阈值化分割算法根据求阈值的不同又可以分为人工选择法&#xff08;主要包括双峰法&#xff09;和自动选择法&#xff08;包括迭代法和最大类间方差法&#xff09;&#xff0c;而区域化分割算法又可以分为区域生长法和区域分裂合并法。在前面章节的研究中&#xff0c;不仅对同一分割算法使用不同的图像进行分割&#xff0c;来比较分割的性能&#xff0c;而且还比较不同的分割算法在对同一个图像进行分割时&#xff0c;分割性能的好坏。使用这样的方法能对每一种分割算法进行全面的分割效果分析&#xff0c;能够得出更准确的结论。

至今&#xff0c;各种文献和专著已经提出了多种不同的分割算法&#xff0c;每种算法的实现方式均不相同&#xff0c;但是都基于图像在像素级的不连续性和相似性。每种算法都有其一定的适用围&#xff0c;但是却没有哪种算法能够适合所有的图像特点&#xff0c;只能根据图像的不同特性或者一定的应用要求来找到适合的算法。

参考文献

[1] 德丰&#xff0e;数字图像处理(MATLAB版)[M]&#xff0e;北京&#xff1a;人民邮电&#xff0c;2009&#xff1a;258-296&#xff0e;

[2] 刚&#xff0e;MATLAB数字图像处理[M]&#xff0e;北京&#xff1a;机械工业&#xff0c;2010&#xff1a;198-222&#xff0e;

[3] 余松煜&#xff0c;周源华&#xff0c;瑞&#xff0e;数字图像处理[M]&#xff0e;上海&#xff1a;上海交通大学&#xff0c;2007&#xff0e;

[4] 天华&#xff0e;数字图像处理[M]&#xff0e;北京&#xff1a;清华大学&#xff0e;2007&#xff0e;

[5] 秦襄培&#xff0e;MATLAB图像处理与页面编程[M]&#xff0e;北京.电子工业&#xff0c;2009&#xff1a;441-469&#xff0e;

[6] 万毅&#xff0e;指纹图像分割技术算法研究[D]&#xff0e;&#xff1a;大学&#xff0c;2011&#xff0e;

[7] 徐琳俊&#xff0e;数字图像分割算法研究[D]&#xff0e;&#xff1a;科技大学&#xff0c;2011&#xff0e;

[8] 猛&#xff0e;静态图像中的人体分割与姿态估计[D]&#xff0e;&#xff1a;理工大学&#xff0c;2011&#xff0e;

[9] 钱智明&#xff0e;图像分割方法研究[D]&#xff0e;&#xff1a;国防科技大学&#xff0c;2010&#xff0e;

[10] 冯艳平&#xff0c;王徽&#xff0e;基于阈值分割和边缘检测的枪支THz图像识别[J]&#xff0e;红外&#xff0c;2011&#xff0c;32(12)&#xff1a;23-26&#xff0e;

[11] 肖辉&#xff0e;彩色图像分割[J]&#xff0e;测绘科技情报&#xff0c;2004&#xff0c;53(4)&#xff1a;6-11&#xff0e;

[12] 罗志宏&#xff0c;冯国灿&#xff0e;一种新变方法在图像分割中的应用[J]&#xff0e;计算机科学&#xff0c;2011&#xff0c;38(12)&#xff1a;263-265&#xff0e;

[13] 强&#xff0e;图像分割中的阈值法研究[J]&#xff0e;职业技术学院学报(自然科学版)&#xff0c;2008&#xff0e;6(6)&#xff1a;52-54&#xff0e;

[14] 王丽&#xff0e;相似背景下的苹果图像分割方法仿真研究[J]&#xff0e;计算机仿真&#xff0c;2011&#xff0c;28(12)&#xff1a;281-284&#xff0e;

[15] 龚声荣&#xff0e;数字图像处理与分析[M]&#xff0e;北京&#xff1a;清华大学&#xff0c;2006&#xff1a;168-208&#xff0e;

[16] 敏&#xff0e;数字图像处理[M]&#xff0e;北京&#xff1a;机械工业&#xff0c;2006&#xff1a;225-262&#xff0e;

[17] Kong W Z&#xff0c;Zhu Sh A&#xff0e;Multi-face detection based on down sampling and modified subtractive clustering for color images[J]&#xff0e;Journal of Zhejiang University Science&#xff0c;2007&#xff0c;8(1)&#xff1a;72-78&#xff0e;

[18] Jain A K&#xff0c;Hsu R L&#xff0c;Mohamed A M&#xff0e;Face detection in color images[J]&#xff0e;IEEE Trans on Pattern Analysis and Machine Intelligence&#xff0c;2002&#xff0c;24(5)&#xff1a;696-706&#xff0e;


推荐阅读
  • 生成式对抗网络模型综述摘要生成式对抗网络模型(GAN)是基于深度学习的一种强大的生成模型,可以应用于计算机视觉、自然语言处理、半监督学习等重要领域。生成式对抗网络 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 提升Python编程效率的十点建议
    本文介绍了提升Python编程效率的十点建议,包括不使用分号、选择合适的代码编辑器、遵循Python代码规范等。这些建议可以帮助开发者节省时间,提高编程效率。同时,还提供了相关参考链接供读者深入学习。 ... [详细]
  • 本文由编程笔记#小编为大家整理,主要介绍了logistic回归(线性和非线性)相关的知识,包括线性logistic回归的代码和数据集的分布情况。希望对你有一定的参考价值。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文介绍了在Python3中如何使用选择文件对话框的格式打开和保存图片的方法。通过使用tkinter库中的filedialog模块的asksaveasfilename和askopenfilename函数,可以方便地选择要打开或保存的图片文件,并进行相关操作。具体的代码示例和操作步骤也被提供。 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 本文讨论了在Windows 8上安装gvim中插件时出现的错误加载问题。作者将EasyMotion插件放在了正确的位置,但加载时却出现了错误。作者提供了下载链接和之前放置插件的位置,并列出了出现的错误信息。 ... [详细]
  • 本文介绍了C#中生成随机数的三种方法,并分析了其中存在的问题。首先介绍了使用Random类生成随机数的默认方法,但在高并发情况下可能会出现重复的情况。接着通过循环生成了一系列随机数,进一步突显了这个问题。文章指出,随机数生成在任何编程语言中都是必备的功能,但Random类生成的随机数并不可靠。最后,提出了需要寻找其他可靠的随机数生成方法的建议。 ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • 解决Cydia数据库错误:could not open file /var/lib/dpkg/status 的方法
    本文介绍了解决iOS系统中Cydia数据库错误的方法。通过使用苹果电脑上的Impactor工具和NewTerm软件,以及ifunbox工具和终端命令,可以解决该问题。具体步骤包括下载所需工具、连接手机到电脑、安装NewTerm、下载ifunbox并注册Dropbox账号、下载并解压lib.zip文件、将lib文件夹拖入Books文件夹中,并将lib文件夹拷贝到/var/目录下。以上方法适用于已经越狱且出现Cydia数据库错误的iPhone手机。 ... [详细]
  • 本文介绍了设计师伊振华受邀参与沈阳市智慧城市运行管理中心项目的整体设计,并以数字赋能和创新驱动高质量发展的理念,建设了集成、智慧、高效的一体化城市综合管理平台,促进了城市的数字化转型。该中心被称为当代城市的智能心脏,为沈阳市的智慧城市建设做出了重要贡献。 ... [详细]
author-avatar
林小琳LLL
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有