图像阈值分割matlab,图像阈值分割Matlab版 | 学步园

图像阈值分割是一个非常简单的

而现在遇到的阈值分割却需要完成如下的多个功能:

1、基本的阈值分割:

大于阈值,则认为是目标;小于,则认为是背景

2、像素值较低才被认为是目标,即要把不等号反向

对图像像素点,小于阈值,认为是目标;大于阈值,则认为是背景。

3、可能进行阈值分割的图像只是标记图像

对标记图像进行分割后,需要在原始的图像上对分割的目标区域进行展示

这就需要输入原始图像

原始图像可能是灰度图像,也有可能是彩色图像

4、多个阈值进行分割

输出每个阈值进行分割的结果

花费了两个小时,完成了单阈值分割完成了功能1、2、3;本来将功能4也整合进来了,但感觉如此一来,代码太过费解,并且有一定的代码冗余,因此将其分离成一个单独的函数,通过调用单阈值分割实现。

功能 2 的实现: 增加一个偏置 标记 bias

若为1,则表示正常情况,大于阈值,则认为是目标

为-1时,则反之。

进行比较时用:bias*image>bias*thresh 对两种情况通用

None.gif% 对标记图像进行阈值分割

None.gif%

None.gif% 标记图像里像素值大于Thresh,则认为时病斑,否则认为是非病斑

None.gif

None.gif% 输入:

None.gif% image     进行阈值分割的图像

None.gif% thresh     分割的阈值

None.gif% bias        分割的偏置,默认为1

None.gif%                bias=+1大于阈值为1,小于阈值为0

None.gif%                bias=-1大于阈值为0,小于阈值为1

None.gif% bgImage   背景图像,image上标识为目标的区域被保留,而标识为背景的则删除

None.gif%                  默认为进行阈值分割的图像,即image

None.gif

None.gif% 输出:

None.gif% labBinaryImage 标识病斑图像、二值图像

None.gif% labSrcImage    在背景图像上作标记,标识病斑区域

None.gif

None.gif%[labBinaryImage,labSrcImage]=ThreshSegement(image,thresh);

None.gif%[labBinaryImage,labSrcImage]=ThreshSegement(image,thresh,bias);

None.gif%[labBinaryImage,labSrcImage]=ThreshSegement(image,thresh,bias,bgimage);

None.gif

None.gif%2007-11-08None.gif

None.giffunction[labBinaryImage,labSrcImage]=ThreshSegement(image,thresh,varargin)

None.gifiptchecknargin(2,4,nargin,mfilename);% 检测输入参数数量None.gifiptcheckinput(image,{'numeric'},{'2d','real','nonsparse'},mfilename,'image',1);

None.gifiptcheckinput(thresh,{'numeric'},{'row','nonempty','real'},mfilename,'thresh',2);

None.gifthresh=thresh(1);% 只取第一个阈值None.gifbias=1;% 偏置,默认为1None.gifif(nargin>2)               % 指定偏置

None.gif    bias=varargin{1};None.gifend

None.gifif(bias~=1)                  % 偏置只允许取值1和-1None.gif    bias=-1;

None.gifend

None.gifimage=double(image);% 类型转换None.gifiptcheckinput(bias,{'numeric'},{'row','nonempty','integer'},mfilename,'bias',3);

None.gifNone.gif

None.gifif(nargin>3)        % 显示的背景图像

None.gif    bgImage=varargin{2};

None.gifif( (size(bgImage,1)~=size(image,1))||(size(bgImage,2)~=size(image,2)) )

None.gif        error('背景图像大小需与分割图像完全一致。');

None.gifend

None.gifelse

None.gif    bgImage=image;% 默认为进行阈值分割的图像imageNone.gifend

None.gifiptcheckinput(bgImage,{'numeric'},{'real','nonsparse'},mfilename,'bgImage',4);

None.gifNone.gif

None.gif% 阈值分割,生成两幅标记图像

None.giflabBinaryImage=zeros(size(image));% 在二值图像上标识病斑区域None.gifNone.giflabBinaryImage(find(bias*image>=bias*thresh))=1;

None.gifNone.gif

None.gifif ( nargout>1)                              % 输出背景图像上标识病斑区域

None.gif    for cur=1:size(bgImage,3)      % 对每个平面均进行标记,灰度图像与彩色图像均可

None.gif        curLabSrcImage=bgImage(:,:,cur);None.gifcurLabSrcImage(find(bias*image

None.giflabSrcImage(:,:,cur)=curLabSrcImage;

None.gifend

None.gifend

但也还存在一个问题,就是边界情况。即 bias*image=bias*thresh 的像素点的类别。bias取不同值其归类规则略有差别。比如归类规则:bias*image>bias*thresh,bias=1时表示大于阈值则认为是目标像素;bias=-1则小于等于阈值认为是目标像素。两者差一个等号。不能做到一致。

你可能感兴趣的:(图像阈值分割matlab)