这篇随笔介绍使用OpenCV进行图像处理的第五章 阈值处理。

5  阈值处理

阈值是指像素到达某临界值。阈值处理表示像素到达某临界值后,对该像素点进行操作和处理。

例如:设定一幅图像素阈值为200,则图片中所有大于200的像素点设置为255,图片中所有小于或等于200的像素点设置为0。

5.1  处理类型

OpenCV中提供了cv2.threshold()函数进行阈值处理。

该函数中,要设定阈值处理的类型,常见类型如下:

cv2.THRESH_BINARY               二值化阈值处理

cv2.THRESH_BINARY _INV      反二值化阈值处理

cv2.THRESH_TRUNC                截断阈值处理

cv2.THRESH_TOZERO_INV      超阈值零处理

cv2.THRESH_TOZERO              低阈值零处理

cv2.THRESH_MASK                   掩码处理

cv2.THRESH_OTSU                   Otsu算法阈值处理

此外,OpenCV还提供了cv2.adaptiveThreshold()函数进行自适应阈值处理。

5.2  二值化阈值处理(cv2.THRESH_BINARY)

该方法表示:对于像素值大于阈值thresh的像素点,将其设置为最大值;对于像素值小于阈值thresh的像素点,将其设置为0。

使用函数cv2.threshold()对图像进行二值化阈值操作代码如下:

1 import cv2
2 img=cv2.imread('E:\python_opencv/tupian.jpg')
3 t,rst=cv2.threshold(img,127,255,cv2.THRESH_BINARY) #类型设置为cv2.THRESH_BINARY,阈值设置为127
4 cv2.imshow('img',img)
5 cv2.imshow('rst',rst)
6 cv2.waitKey()
7 cv2.destroyAllWindows()

运行结果如下图,左为原图像,右为二值化阈值处理结果。

5.3  反二值化阈值处理(cv2.THRESH_BINARY_INV)

该方法表示:对于像素值大于阈值thresh的像素点,将其设置为0;对于像素值小于阈值thresh的像素点,将其设置为最大值。

使用函数cv2.threshold()对图像进行二值化阈值操作代码如下:

1 import cv2
2 img=cv2.imread('E:\python_opencv/tupian.jpg')
3 t,rst=cv2.threshold(img,127,255,cv2.THRESH_BINARY_INV) #类型设置为cv2.THRESH_BINARY_INV,阈值设置为127
4 cv2.imshow('img',img)
5 cv2.imshow('rst',rst)
6 cv2.waitKey()
7 cv2.destroyAllWindows()

运行结果如下图,左为原图像,右为反二值化阈值处理结果。

5.4  截断阈值化处理(cv2.THRESH_TRUNC)

该方法表示:对于像素值大于阈值thresh的像素点,将其设置为阈值;对于像素值小于阈值thresh的像素点,保持不变。

使用函数cv2.threshold()对图像进行截断阈值化处理代码如下:

1 import cv2
2 img=cv2.imread('E:\python_opencv/tupian.jpg')
3 t,rst=cv2.threshold(img,127,255,cv2.THRESH_TRUNC) #类型设置为cv2.THRESH_TRUNC,阈值设置为127
4 cv2.imshow('img',img)
5 cv2.imshow('rst',rst)
6 cv2.waitKey()
7 cv2.destroyAllWindows()

运行结果如下图,左为原图像,右为截断阈值化处理结果。

5.5  超阈值零处理(cv2.THRESH_TOZERO_INV)

该方法表示:对于像素值大于阈值thresh的像素点,将其设置为0;对于像素值小于阈值thresh的像素点,保持不变。

使用函数cv2.threshold()对图像进行超阈值零处理代码如下:

1 import cv2
2 img=cv2.imread('E:\python_opencv/tupian.jpg')
3 t,rst=cv2.threshold(img,127,255,cv2.THRESH_TOZERO_INV) #类型设置为cv2.THRESH_TOZERO_INV,阈值设置为127
4 cv2.imshow('img',img)
5 cv2.imshow('rst',rst)
6 cv2.waitKey()
7 cv2.destroyAllWindows()

运行结果如下图,左为原图像,右为超阈值零处理结果。

5.6  低阈值零处理(cv2.THRESH_TOZERO)

该方法表示:对于像素值小于或等于阈值thresh的像素点,将其设置为0;对于像素值大于阈值thresh的像素点,保持不变。

使用函数cv2.threshold()对图像进行低阈值零处理代码如下:

1 import cv2
2 img=cv2.imread('E:\python_opencv/tupian.jpg')
3 t,rst=cv2.threshold(img,127,255,cv2.THRESH_TOZERO) #类型设置为cv2.THRESH_TOZERO,阈值设置为127
4 cv2.imshow('img',img)
5 cv2.imshow('rst',rst)
6 cv2.waitKey()
7 cv2.destroyAllWindows()

运行结果如下图,左为原图像,右为低阈值零处理结果。

5.7  自适应阈值处理

一般情况下,图像中只是用一个阈值,就会造成轮廓与内容分割不均衡,无法得到清晰有效的阈值处理图像。

OpenCV中提供了cv2.adaptiveThreshold()函数用于实现自适应阈值处理。自适应阈值处理的原理,是通过计算每个像素点的邻域像素进行加权平均而获得阈值,能够较好地处理色彩不均衡的图像。

cv2.adaptiveThreshold()函数中,有两个参数类型:

cv2.ADAPTIVE_THRESH_MEAN_C             邻域内所有像素点的权重都相同

cv2.ADAPTIVE_THRESH_GAUSSIAN_C     通过高斯方程得到各个像素点的权重值,与邻域内像素点到中心的距离有关

使用二值化阈值函数cv2.threshold()对图像进行自适应阈值处理代码如下:

 1 import cv2
2 img=cv2.imread('E:\python_opencv/tupian.jpg',0)
3 #类型设置为cv2.ADAPTIVE_THRESH_MEAN_C,后面必须加cv2.THRESH_BINARY或cv2.THRESH_BINARY_INV,邻域大小设置为5×5,最后的3是常量
4 athdMEAN=cv2.adaptiveThreshold(img,255,cv2.ADAPTIVE_THRESH_MEAN_C,cv2.THRESH_BINARY,5,3)
5 #类型设置为cv2.ADAPTIVE_THRESH_GAUSSIAN_C,后面必须加cv2.THRESH_BINARY或cv2.THRESH_BINARY_INV,邻域大小设置为5×5,最后的3是常量
6 athdGAUS=cv2.adaptiveThreshold(img,255,cv2.ADAPTIVE_THRESH_GAUSSIAN_C,cv2.THRESH_BINARY,5,3)
7 cv2.imshow('img',img)
8 cv2.imshow('athdMEAN',athdMEAN)
9 cv2.imshow('athdGAUS',athdGAUS)
10 cv2.waitKey()
11 cv2.destroyAllWindows()

运行结果如下图,左为原图像,中为像素权重平均处理结果,右为高斯权重值处理结果。可以看到,自适应阈值处理保留了更多的细节信息。

5.8  Otsu方法

Otsu方法能够根据当前图像生成最佳的类间分割阈值,原理是遍历所有可能的阈值,从而找到最合适的阈值。

通过函数cv2.threshold()中传递类型参数:cv2.THRESH_OTSU,来实现Otsu算法。

需要注意的是,在使用Otsu方法时,要把阈值设置为0,语句为:

# t是Otsu方法得到并使用的最合适阈值,参数中阈值设置为0,传递两种类型
t,otsu=cv2.threshold(img,0,255,cv2.THRESH_BINARY+cv2.THRESH_OTSU)

使用Otsu方法对图像进行自适应阈值处理代码如下:

1 import cv2
2 img=cv2.imread('E:\python_opencv/tupian.jpg',0)
3 #类型设置为cv2.THRESH_BINARY+cv2.THRESH_OTSU,阈值设置为0
4 t,otsu=cv2.threshold(img,0,255,cv2.THRESH_BINARY+cv2.THRESH_OTSU)
5 cv2.imshow('img',img)
6 cv2.imshow('otsu',otsu)
7 cv2.waitKey()
8 cv2.destroyAllWindows()

运行结果如下图,左为原图像,右为Otsu方法处理结果。

这次内容就分享到这里了,下次继续更新第6章 图像平滑处理,希望与各位老师和小伙伴们交流学习~

【图像处理】OpenCV+Python图像处理入门教程(五)阈值处理的更多相关文章

  1. PySide——Python图形化界面入门教程(五)

    PySide——Python图形化界面入门教程(五) ——QListWidget 翻译自:http://pythoncentral.io/pyside-pyqt-tutorial-the-qlistw ...

  2. 无废话ExtJs 入门教程五[文本框:TextField]

    无废话ExtJs 入门教程五[文本框:TextField] extjs技术交流,欢迎加群(201926085) 继上一节内容,我们在表单里加了个两个文本框.如下所示代码区的第42行位置,items: ...

  3. Python基础入门教程

    Python基础入门教程 Python基础教程 Python 简介 Python环境搭建 Python 基础语法 Python 变量类型 Python 运算符 Python 条件语句 Python 循 ...

  4. Python爬虫入门教程 48-100 使用mitmdump抓取手机惠农APP-手机APP爬虫部分

    1. 爬取前的分析 mitmdump是mitmproxy的命令行接口,比Fiddler.Charles等工具方便的地方是它可以对接Python脚本. 有了它我们可以不用手动截获和分析HTTP请求和响应 ...

  5. Python爬虫入门教程 43-100 百思不得姐APP数据-手机APP爬虫部分

    1. Python爬虫入门教程 爬取背景 2019年1月10日深夜,打开了百思不得姐APP,想了一下是否可以爬呢?不自觉的安装到了夜神模拟器里面.这个APP还是比较有名和有意思的. 下面是百思不得姐的 ...

  6. 2019-03-22 Python Scrapy 入门教程 笔记

    Python Scrapy 入门教程 入门教程笔记: # 创建mySpider scrapy startproject mySpider # 创建itcast.py cd C:\Users\theDa ...

  7. Elasticsearch入门教程(五):Elasticsearch查询(一)

    原文:Elasticsearch入门教程(五):Elasticsearch查询(一) 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:h ...

  8. RabbitMQ入门教程(五):扇形交换机发布/订阅(Publish/Subscribe)

    原文:RabbitMQ入门教程(五):扇形交换机发布/订阅(Publish/Subscribe) 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. ...

  9. 【图像处理】OpenCV+Python图像处理入门教程(四)几何变换

    这篇随笔介绍使用OpenCV进行图像处理的第四章 几何变换. 4  几何变换 图像的几何变换是指将一幅图像映射到另一幅图像内.有缩放.翻转.仿射变换.透视.重映射等操作. 4.1  缩放 使用cv2. ...

随机推荐

  1. 使用 js 实现十大排序算法: 计数排序

    使用 js 实现十大排序算法: 计数排序 计数排序 refs xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!

  2. Parcel all in one

    Parcel all in one Parcel https://parceljs.org/ # cli $ yarn global add parcel-bundler $ npm install ...

  3. 召回 & 召回算法

    召回 & 召回算法 recall https://developers.google.com/machine-learning/crash-course/classification/prec ...

  4. USDN代币的特点

    USDN是NGK公链发行的算法型稳定币,采用智能合约发行,通过智能合约的透明化,能够让市场USND持有者获得算法稳定的背书.USDN是一种锚定全球通用的代币,更是连接全球数字经济的通用数字代币.USD ...

  5. Masterboxan INC金融:在区块链技术基础上推动业务模式的变革创新

    10月初,2020年国际区块链技术与应用大会在硅谷开幕,全球内外区块链技术项目团队.行业领导.专家等共聚一堂,围绕区块链技术与应用展开讨论交流.美国Masterboxan INC万事达资产管理有限公司 ...

  6. Spring学习过程中遇到的No bean named 'beanId' is defined报错

    ApplicationContext applicationContext= new ClassPathXmlApplicationContext("bean.xml");Obje ...

  7. 防抖和节流及对应的React Hooks封装

    Debounce debounce 原意消除抖动,对于事件触发频繁的场景,只有最后由程序控制的事件是有效的. 防抖函数,我们需要做的是在一件事触发的时候设置一个定时器使事件延迟发生,在定时器期间事件再 ...

  8. 数据库分表自增ID问题

    .................................................................................................... ...

  9. Tawk.to一键给自己的网站增加在线客服功能

    Tawk.to一键给自己的网站增加在线客服功能 很多外贸网站只有contact页面,留下邮箱.电话等联系方式,而在国际贸易当中能够及时在线交流沟通,能给客户留下更好的印象.接下来,就让我们一起来了解一 ...

  10. 基于3.X版本的脚手架创建VUE项目

    一.基于交互式命令行的方式,创建vue项目 1.命令:vue create 项目名称.项目名称必须是英文的.不要包含中文.特殊的字符和符号.在cmd中输入命令:vue create vue_proje ...