基于Otsu算法的图像自适应阈值切割
在图像处理实践中,将灰度图转化为二值图是非经常见的一种预处理手段。
在Matlab中,能够使用函数BW = im2bw(I, level)来将一幅灰度图 I。转化为二值图。
当中。參数level是一个介于0~1之间的值,也就是用于切割图像的阈值。默认情况下,它可取值是0.5。
如今问题来了,有没有一种依据图像自身特点来自适应地选择阈值的方法呢?答案是肯定的!我们今天就来介绍当中最为经典的Otsu算法(或称大津算法)。该算法由日本科学家大津展之(Nobuyuki Otsu)于1979年提出。这个算法看似简单,却与统计分析中的“方差分析”方法有非常深的渊源。有兴趣的读者也能够參考算法原文《A threshold selection method from gray-level histograms》(在线浏览地址:http://wenku.baidu.com/view/996e972d7375a417866f8f5d)我们今天在介绍该算法原理的基础之上,通过简单的Matlab代码来演示它的实现。
Matlab的帮助信息中指出:To compute the level argument,you can use the function graythresh. The graythresh function uses Otsu's method。可见,函数graythresh()就是Matlab中的大津法实现。假设对Otsu算法的原理并不感兴趣,全然能够直接调用graythresh()函数,而无需过多关系当中的技术细节。
在大津法中,我们定义组内方差为
通过选择使得上述组内方差最小化时的阈值 t,就能够使得图像中的前景和背景尽可能的被差别开(假设我们将终于图像里被分开的两部分称为前景和背景)。w0和w1各自是一个像素可能属于前景或背景的概率。而 σ 表示两个类别的方差。假设一个图像的直方图有L个等级(一般L=256)。那么在给定阈值 t的情况下,w0和w1分别定义为
大津展之证明最小化组内方差(intra-class variance)与最大化组间方差(inter-class variance)是等价的,于是有
又由于(当中 μ 表示均值或期望)
能够推出
这个证明只涉及一些算术上的推导,我简单演演示样例如以下
最后我们给出在Matlab中实现的代码,这个代码的最初版本号来自维基百科。为了与前面的公式中的标记相一致,我略有改动。
function level = otsu(histogramCounts, total)
sum0 = 0;
w0 = 0;
maximum = 0.0;
total_value = sum((0:255).*histogramCounts');
for ii=1:256
w0 = w0 + histogramCounts(ii);
if (w0 == 0)
continue;
end
w1 = total - w0;
if (w1 == 0)
break;
end
sum0 = sum0 + (ii-1) * histogramCounts(ii);
m0 = sum0 / w0;
m1 = (total_value - sum0) / w1;
icv = w0 * w1 * (m0 - m1) * (m0 - m1);
if ( icv >= maximum )
level = ii;
maximum = icv;
end
end end
上述函数中的參数histogramCounts是图像的直方图, total图像的总像素数。
来看以下这段调用上述函数的測试代码。
>> img = imread('otsus_test.jpg');
>> [counts x] = imhist(img);
>> [m n] = size(img);
>> level = otsu(counts, m*n);
>> output = img;
>> output(output<level) = 0;
>> output(output>=level) = 255;
>> imshow(output)
首先给出原始图像
然后是基于Otsu算法获取的二值图
很多其它有趣实用的图像处理算法还能够參考我的《数字图像处理原理与实践(Matlab版)》。
基于Otsu算法的图像自适应阈值切割的更多相关文章
- python+opencv实现图像自适应阈值的均衡化
内容涉及:列表遍历,图像均衡化,图像通道分离与合并 import cv2 import numpy as np import os for path in open("org_junheng ...
- 大津法---OTSU算法
简介: 大津法(OTSU)是一种确定图像二值化分割阈值的算法,由日本学者大津于1979年提出.从大津法的原理上来讲,该方法又称作最大类间方差法,因为按照大津法求得的阈值进行图像二值化分割后,前景与背景 ...
- 自适应阈值化操作:adaptiveThreshold()函数
在图像阈值化操作中,更关注的是从二值化图像中,分离目标区域和背景区域,但是仅仅通过设定固定阈值很难达到理想的分割效果.而自适应阈值,则是根据像素的邻域块的像素值分布来确定该像素位置上的二值化阈值.这样 ...
- 用OpenCV实现Otsu算法
算法的介绍 otsu法(最大类间方差法,有时也称之为大津算法)使用的是聚类的思想,把图像的灰度数按灰度级分成2个部分,使得两个部分之间的灰度值差异最大,每个部分之间的灰度差异最小,通过方差的计算来寻找 ...
- 《opencv学习》 之 OTSU算法实现二值化
主要讲解OTSU算法实现图像二值化: 1.统计灰度级图像中每个像素值的个数. 2.计算第一步个数占整个图像的比例. 3.计算每个阈值[0-255]条件下,背景和前景所包含像素值总个数和总概率(就 ...
- OpenCV_基于局部自适应阈值的图像二值化
在图像处理应用中二值化操作是一个很常用的处理方式,例如零器件图片的处理.文本图片和验证码图片中字符的提取.车牌识别中的字符分割,以及视频图像中的运动目标检测中的前景分割,等等. 较为常用的图像二值化方 ...
- 自适应阈值分割—大津法(OTSU算法)C++实现
大津法是一种图像灰度自适应的阈值分割算法,是1979年由日本学者大津提出,并由他的名字命名的.大津法按照图像上灰度值的分布,将图像分成背景和前景两部分看待,前景就是我们要按照阈值分割出来的部分.背景和 ...
- Wellner 自适应阈值二值化算法
参考文档: Adaptive Thresholding for the DigitalDesk.pdf Adaptive Thresholding Using the Integral I ...
- opencv —— threshold、adaptiveThreshold 固定阈值 & 自适应阈值 进行图像二值化处理
阈值化 在对图像进行处理操作的过程中,我们常常需要对图像中的像素做出取舍与决策,直接剔除一些低于或高于一定值的像素. 阈值分割可以视为最简单的图像分割方法.比如基于图像中物体与背景之间的灰度差异,可以 ...
随机推荐
- ubuntun 18.04 desktop安装jupyter-notebook
在ubuntu18.04要安装jupyter-notebook,当然前提是先安装python,然后按如下步骤安装jupyter-notebook,现在记录如下: 1.sudo apt-get upda ...
- 002.FTP配置项详解
一 相关配置项 anonymous_enable=YES #允许匿名用户登录 local_enable=YES #允许本地用户登录 write_enable=YES #允许本地用户上传 local_u ...
- 学习字典才联想到要和 JSP 说再见了
最开始只是想让页面能够映射出我的字典值,然而却发现了更大的问题. 假如你自己做一个 demo ,需要前台页面映射出字典数据你会怎么做呢?大致的思路应该是有的,准备字典,准备数据,然后将两部分进行映射. ...
- Eclipse设置之:代码注释/server 控制台输出乱码解决
1 Eclipse设置 Configure clean up style The location is here: And the configuration should fo ...
- BZOJ2217 : [Poi2011]Lollipop
若能得到一个和为t的区间,那么至少去掉两端点中任意一个后必定能得到和为t-2的区间. 所以只需要分别找到和最大的和为奇数和偶数的区间,然后$O(n)$完成构造即可. #include<cstdi ...
- POP3_收取QQ邮箱邮件的问题
今天纠结了一天的时间,使用pop3协议收取qq邮箱中邮件时,因为一个特别坑爹的问题重新写n次,最后发现是因为qq邮箱设置了独立邮箱密码,必须的用独立邮箱密码登陆才行,/(ㄒoㄒ)/~~!!!! 但今天 ...
- [原创] 浅谈ETL系统架构如何测试?
[原创] 浅谈ETL系统架构如何测试? 来新公司已入职3个月时间,由于公司所处于互联网基金行业,基金天然固有特点,基金业务复杂,基金数据信息众多,基金经理众多等,所以大家可想一下,基民要想赚钱真不容易 ...
- Android中pm命令用法(转)
usage: pm [list|path|install|uninstall] pm list packages [-f] pm list permission-groups pm list perm ...
- Eclipse 正则表达式 查找与替换
CTRL + space in the textboxes gives you all kinds of suggestions for regular expression writing. 查找 ...
- 【Go命令教程】5. go clean
执行 go clean 命令会删除掉执行其它命令时产生的一些文件和目录,包括: 在使用 go build 命令时在当前代码包下生成的与包名同名或者与Go源码文件同名的可执行文件.在Windows下,则 ...