大津阈值分割算法(OTSU处理图像)

1.算法原理简述

        对于图像I(x,y),前景(即目标)和背景的分割阈值记作T,属于前景的像素点数占整幅图像的比例记为ω0,其平均灰度μ0;背景像素点数占整幅图像的比例为ω1,其平均灰度为μ1。图像的总平均灰度记为μ,类间方差记为g。

假设图像的背景较暗,并且图像的大小为M×N,图像中像素的灰度值小于阈值T的像素个数记作N0,像素灰度大于阈值T的像素个数记作N1,则有:

ω0=N0/ M×N (1)

ω1=N1/ M×N (2)

N0+N1=M×N (3)

ω0+ω1=1 (4)

μ=ω0*μ0+ω1*μ1 (5)

g=ω0(μ0-μ)^2+ω1(μ1-μ)^2 (6)

将式(5)代入式(6),

得到等价公式:

g=ω0ω1(μ0-μ1)^2 (7)

这就是类间方差采用遍历的方法得到使类间方差g最大的阈值T,即为所求。

2.算法设计流程图(或难点分析)

 

 

3.算法设计代码与注释(大津阈值)

简单处理)

I=im2double(imread('cell.jpg'));

k=graythresh(I); %得到最优阈值

J=im2bw(I,k); %转换成二值图,k为分割阈值

subplot(121);imshow(I);title('Original');%显示原图

subplot(122);imshow(J); title('Processed') ;%显示处理后的图像

(复杂处理)

I=rgb2gray(imread('cell.jpg')); %读图并转化为灰度图

subplot(121);imshow(I);title('Original'); %显示原图灰度图

Ni=imhist(I); %计算直方图数组

N=sum(Ni); %总像素点个数

delamax=0; %类间方差最大值初始化

threshold=0; %阈值初始化

for k=2:255

u=dot([0:255],Ni/N); %图像的总平均灰度级

w0=sum(Ni(1:k)/N); %前景类像素所占面积的比例

w1=1-w0; %背景类像素所占面积的比例

if w0==0|w0==1 %当w0为1或0时提前结束本次循环

continue

end

u0=dot([0:k-1],Ni(1:k)/N)/w0; %前景类像素的平均灰度

u1=dot([k:255],Ni(k+1:256)/N)/w1; %背景类像素的平均灰度

dela(k)=w0*(u-u0)^2+w1*(u-u1)^2; %类间方差

%求出类间方差的最大值,最大时的那个值对应的k值存入delamax

if dela(k)>delamax

delamax=dela(k);

threshold=k-1;

end

end

%以下为阈值分割程序

[width,height]=size(I); %获取图片宽高

for i=1:width

for j=1:height

if(I(i,j)<threshold) %灰度小于阈值时则为黑色

BW1(i,j)=0;

else

BW1(i,j)=1; %灰度大于阈值时则为白色

end

end

end

subplot(122);imshow(BW1);title('Processed')%显示处理之后的图像

figure;histogram(I);xlim([0 255]); %显示原图灰度图的直方图

4.实验结果与分析

 

图1 细胞图像处理图

 

图2 细胞原图直方图

图1为使用细胞图像进行处理之后的图像,其中Original标题的为细胞图像原图,Processed标题的图像为进行OTSU算法处理之后的图像。从图1的对比当中,可以看到使用OTSU之后图像被处理的结果。它相对于迭代阈值分割算法来说得出的结果更好,可以很明显的分割出光学显微镜下的细胞。图2为细胞原图灰度化之后的直方图。

5.结论与展望

       大津法的优点在于可以快速有效的找到类间分割阈值,但其缺点也很明显,就是只能针对单一目标分割,或者感兴趣的目标都属于同一灰度范围,若需探测目标灰度范围分布较大,则必将有一部分目标探测丢失。

  • 22
    点赞
  • 214
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
### 回答1: 使用OpenCV库可以很方便地实现固定阈值分割算法。下面是一个示例代码: ```python import cv2 # 读取图像,使用灰度模式 img = cv2.imread('image.jpg', cv2.IMREAD_GRAYSCALE) # 选定阈值 threshold = 127 # 对图像进行分割 ret, binary = cv2.threshold(img, threshold, 255, cv2.THRESH_BINARY) # 显示分割结果 cv2.imshow('binary', binary) cv2.waitKey(0) cv2.destroyAllWindows() ``` 首先使用cv2.imread函数读取图像,并使用cv2.IMREAD_GRAYSCALE模式将图像转换成灰度图像。然后选定阈值,使用cv2.threshold函数对图像进行分割,得到二值化图像。最后使用cv2.imshow函数显示分割结果,并使用cv2.waitKey和cv2.destroyAllWindows函数等待用户按下键盘上的任意键,然后关闭所有窗口。 需要注意的是,如果图像路径不在当前工作目录下,需要使用绝对路径或相对路径来指定图像路径。另外,阈值的选取需要根据具体情况进行调整,以获得最佳的分割效果。 ### 回答2: OpenCV中的固定阈值分割算法是一种简单而常用的图像分割方法,其基本原理是将图像的像素值与预先设定的阈值进行比较,根据比较的结果将像素分为不同的区域。 编写固定阈值分割算法可以分为以下步骤: 1. 导入必要的库文件,包括OpenCV库和相关的头文件。 2. 读取待分割的图像,可以使用OpenCV提供的函数`cv::imread()`。 3. 对图像进行预处理,例如转换为灰度图像,可以使用OpenCV提供的函数`cv::cvtColor()`。 4. 根据应用的需求,选择合适的阈值类型,包括二进制阈值、反二进制阈值、截断阈值等等。 5. 通过调用OpenCV提供的函数`cv::threshold()`,将图像的像素值与设定的阈值进行比较,得到阈值分割的结果。 6. 可选的,对分割结果进行后处理,例如去除噪声,可以使用OpenCV提供的函数`cv::erode()`和`cv::dilate()`。 7. 输出分割结果图像,可以使用OpenCV提供的函数`cv::imwrite()`。 编写固定阈值分割算法的关键在于调用OpenCV提供的函数来实现图像处理的各个步骤,并根据具体应用的需求选择合适的参数和方法。需要注意的是,对于不同的图像和阈值选择,可能需要进行一定的调试和优化才能得到最好的分割效果。 ### 回答3: Opencv是一个开源的计算机视觉库,提供了许多图像处理图像分割的功能。固定阈值分割算法是一种常用的图像分割方法,其基本思想是将图像根据像素的灰度值与设定的阈值进行比较,将像素值大于阈值的部分设置为一个固定值,小于阈值的部分设置为另一个固定值,从而将图像分成两部分。 在Opencv中,可以使用函数`threshold`来实现固定阈值分割算法。该函数的原型如下: ``` threshold(InputArray src, OutputArray dst, double thresh, double maxval, int type); ``` 其中,`src`是输入图像,`dst`是输出图像,`thresh`是设定的阈值,`maxval`是设定的最大值,`type`是阈值分割的类型,有多种选项。 例如,假设我们要将一张彩色图像进行固定阈值分割,设定阈值为100,将大于100的部分设置为255,小于100的部分设置为0,可以使用以下代码实现: ```python import cv2 # 读取图片 img = cv2.imread('image.jpg', 0) # 创建输出图像 dst = np.zeros_like(img) # 阈值分割 threshold_value = 100 max_value = 255 cv2.threshold(img, threshold_value, max_value, cv2.THRESH_BINARY, dst) # 在窗口中显示结果 cv2.imshow('Threshold Image', dst) cv2.waitKey(0) cv2.destroyAllWindows() ``` 以上就是使用Opencv编写固定阈值分割算法的简单示例。通过这个方法,我们可以对图像进行二值化处理,得到分割后的结果,从而便于后续的图像处理和分析任务。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值