Python图像阈值化处理及算法比对实例解析
作者:程序欲向 发布时间:2022-08-14 19:32:33
图像的二值化或阈值化(Binarization)旨在提取图像中的目标物体,将背景以及噪声区分开来。通常会设定一个阈值T,通过T将图像的像素划分为两类:大于T的像素群和小于T的像素群。
灰度转换处理后的图像中,每个像素都只有一个灰度值,其大小表示明暗程度。二值化处理可以将图像中的像素划分为两类颜色,常用的二值化算法如公式1所示:
{Y=0,gray<TY=255,gray>=T
{Y=0,gray<TY=255,gray>=T
当灰度Gray小于阈值T时,其像素设置为0,表示黑色;当灰度Gray大于或等于阈值T时,其Y值为255,表示白色。
Python OpenCV中提供了阈值函数threshold()实现二值化处理,其公式及参数如下图所示:
retval, dst = cv2.threshold(src, thresh, maxval, type)
二进制阈值化
该方法先要选定一个特定的阈值量,比如127
1) 大于等于127的像素点的灰度值设定为最大值
2) 灰度值小于127的像素点的灰度值设置为0
例如: 156->255 89->0
关键字为cv2.THRESH_BINARY,完整代码如下
import cv2
def test22():
src = cv2.imread("rose.jpg")
# 灰度图片转换
GrayImage = cv2.cvtColor(src, cv2.COLOR_BGR2BGRA)
# 二进制阈值化处理
r, b = cv2.threshold(GrayImage, 127, 255, cv2.THRESH_BINARY)
# 显示图像
cv2.imshow("src", src)
cv2.imshow("result", b)
if cv2.waitKey(0) == 27:
cv2.destroyAllWindows()
test22()
效果如下:
反二进制阈值化
该方法与二进制阈值化方法相似,先要选定一个特定的灰度值作为阈值,比如127
1) 大于127的像素点的灰度值设定为0
2) 小于该阈值的灰度值设定为255
例如:156->0 89->255
关键字为cv2.THRESH_BINARY_INV
代码如下:
import cv2
def test22():
src = cv2.imread("rose.jpg")
# 灰度图片转换
GrayImage = cv2.cvtColor(src, cv2.COLOR_BGR2BGRA)
# 二进制阈值化处理
r, b = cv2.threshold(GrayImage, 127, 255, cv2.THRESH_BINARY_INV)
# 显示图像
cv2.imshow("src", src)
cv2.imshow("result", b)
if cv2.waitKey(0) == 27:
cv2.destroyAllWindows()
test22()
效果如下:
截断阈值化
该方法需要选定一个阈值,图像中大于该阈值的像素点被设定为该阈值,小于该阈值的保持不变。
1) 大于等于127像素点的灰度值设定为该阈值127
2) 小于该阈值的灰度值不变
例如: 163-> 127 89->89
关键字cv2.THRESH_TRUNC,完整代码如下
import cv2
def test22():
src = cv2.imread("rose.jpg")
# 灰度图片转换
GrayImage = cv2.cvtColor(src, cv2.COLOR_BGR2BGRA)
# 二进制阈值化处理
r, b = cv2.threshold(GrayImage, 127, 255, cv2.THRESH_TRUNC)
# 显示图像
cv2.imshow("src", src)
cv2.imshow("result", b)
if cv2.waitKey(0) == 27:
cv2.destroyAllWindows()
test22()
效果如下:
反阈值化为0
该方法先选定一个阈值,比如127
(1) 大于等于阈值127的像素点变为0
(2) 小于该阈值的像素点值保持不变
例如: 128->0 89->89
关键字为cv2.THRESH_TOZERO_INV,完整代码如下:
import cv2
def test22():
src = cv2.imread("rose.jpg")
# 灰度图片转换
GrayImage = cv2.cvtColor(src, cv2.COLOR_BGR2BGRA)
# 二进制阈值化处理
r, b = cv2.threshold(GrayImage, 127, 255, cv2.THRESH_TOZERO_INV)
# 显示图像
cv2.imshow("src", src)
cv2.imshow("result", b)
if cv2.waitKey(0) == 27:
cv2.destroyAllWindows()
test22()
效果如下:
阈值为0
该方法先选定一个阈值,比如127
(1) 大于等于阈值127的像素点,值保持不变
(2) 小于该阈值的像素点值设置为0
例如: 163->163 102->0
关键字为cv2.THRESH_TOZERO,完整代码如下:
import cv2
def test22():
src = cv2.imread("rose.jpg")
# 灰度图片转换
GrayImage = cv2.cvtColor(src, cv2.COLOR_BGR2BGRA)
# 二进制阈值化处理
r, b = cv2.threshold(GrayImage, 127, 255, cv2.THRESH_TOZERO)
# 显示图像
cv2.imshow("src", src)
cv2.imshow("result", b)
if cv2.waitKey(0) == 27:
cv2.destroyAllWindows()
test22()
效果如下:
来源:https://www.cnblogs.com/zhouzetian/p/13149524.html


猜你喜欢
- 背景是:在实际开发中,可能会遇到网络问题或者查询量比较大的情况,上一个请求还没有完成,用户就发起了下一个请求。会造成什么情况呢?但是同一个请
- 但是,当一本书学过之后,对一般的技术和函数都有了印象,突然想要查找某个函数的实例代码时,却感到很困难,因为一本书的源代码目录很长,往往有几十
- 一、selenium截取验证码import jsonfrom io import BytesIOimport timefrom test.t
- 前言在上一篇文中,我们介绍了关于Python正则表达式的基础,那么在这一篇文章里,我们将总结一下正则表达式关于捕获的用法。下面话不多说,来看
- 问题:python spyder先出现dos窗口,然后后面就什么都没有了。解决方法:C:\用户\Administrator\.spyder3
- Django中Models是什么:通常,一个Model对应一张数据表,Django中Models以类的形式表现,它包含一些基本字段以及数据的
- 官方函数DataFrame.locAccess a group of rows and columns by label(s) or a b
- 首先我们来看一个公式,MySQL中内存分为全局内存和线程内存两大部分(其实并不全部,只是影响比较大的 部分):per_thread_buff
- 目录1.按照一列数值进行排序1.1按照五缺失值的一列进行排序1.1.1升序排列1.1.2 降序排列1.2按照有缺失值的一列进行排序1.2.1
- 图片上传在项目中经常用到,几乎没有任何一个项目可以脱离图片或者是文件上传。本篇我在这向大家介绍两种常规的上传方式。(注:在这里我们仅仅是对功
- 在照着Tensorflow官网的demo敲了一遍分类器项目的代码后,运行倒是成功了,结果也不错。但是最终还是要训练自己的数据,所以尝试准备加
- 07年,我是极力推崇网站规范制作,好处很多,对商业,对用户,对设计师。我们走了两年,现在有了一定的成效,我们也看到了规范所带来的好处和便利。
- 先看看单条 SQL 语句的分页 SQL 吧。 方法1: 适用于 SQL Server 2000/2005 SELECT TOP 页大小 *
- 本文实例讲述了Python基于多线程实现ping扫描功能。分享给大家供大家参考,具体如下:# -*- coding:utf-8 -*-#!
- 本文实例讲述了Python实现文件按照日期命名的方法。分享给大家供大家参考。具体实现方法如下:这里实现文件按照创建的时期批量重命名的功能#
- 应该只是一个简单的层的定位及鼠标事件吧<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.
- 今天在用python3+ImageFont输出中文时,结果显示乱码# coding:utf-8from PIL import Image,
- #!/usr/bin/env python# -*- coding:utf-8 -*-# *************************
- IE的特殊性 IE的DOM元素属性与Firefox, Opera, Safari有些不同。在IE中,我们可以给DOM添加任意自定
- 需求:启动程序后,让用户输入工资,然后打印商品列表允许用户根据商品编号购买商品用户选择商品后,检测余额是否够,够就直接扣款,不够就提醒可随时