Python图像处理二值化方法实例汇总
作者:ttweixiao9999 时间:2021-04-10 21:41:33
在用python进行图像处理时,二值化是非常重要的一步,现总结了自己遇到过的6种 图像二值化的方法(当然这个绝对不是全部的二值化方法,若发现新的方法会继续新增)。
1. opencv 简单阈值 cv2.threshold
2. opencv 自适应阈值 cv2.adaptiveThreshold (自适应阈值中计算阈值的方法有两种:mean_c 和 guassian_c ,可以尝试用下哪种效果好)
3. Otsu's 二值化
例子:
import cv2
import numpy as np
from matplotlib import pyplot as plt
img = cv2.imread('scratch.png', 0)
# global thresholding
ret1, th1 = cv2.threshold(img, 127, 255, cv2.THRESH_BINARY)
# Otsu's thresholding
th2 = cv2.adaptiveThreshold(img, 255, cv2.ADAPTIVE_THRESH_MEAN_C, cv2.THRESH_BINARY, 11, 2)
# Otsu's thresholding
# 阈值一定要设为 0 !
ret3, th3 = cv2.threshold(img, 0, 255, cv2.THRESH_BINARY + cv2.THRESH_OTSU)
# plot all the images and their histograms
images = [img, 0, th1, img, 0, th2, img, 0, th3]
titles = [
'Original Noisy Image', 'Histogram', 'Global Thresholding (v=127)',
'Original Noisy Image', 'Histogram', "Adaptive Thresholding",
'Original Noisy Image', 'Histogram', "Otsu's Thresholding"
]
# 这里使用了 pyplot 中画直方图的方法, plt.hist, 要注意的是它的参数是一维数组
# 所以这里使用了( numpy ) ravel 方法,将多维数组转换成一维,也可以使用 flatten 方法
# ndarray.flat 1-D iterator over an array.
# ndarray.flatten 1-D array copy of the elements of an array in row-major order.
for i in range(3):
plt.subplot(3, 3, i * 3 + 1), plt.imshow(images[i * 3], 'gray')
plt.title(titles[i * 3]), plt.xticks([]), plt.yticks([])
plt.subplot(3, 3, i * 3 + 2), plt.hist(images[i * 3].ravel(), 256)
plt.title(titles[i * 3 + 1]), plt.xticks([]), plt.yticks([])
plt.subplot(3, 3, i * 3 + 3), plt.imshow(images[i * 3 + 2], 'gray')
plt.title(titles[i * 3 + 2]), plt.xticks([]), plt.yticks([])
plt.show()
结果图:
4. skimage niblack阈值
5. skimage sauvola阈值 (主要用于文本检测)
例子:
https://scikit-image.org/docs/dev/auto_examples/segmentation/plot_niblack_sauvola.html
import matplotlib
import matplotlib.pyplot as plt
from skimage.data import page
from skimage.filters import (threshold_otsu, threshold_niblack,
threshold_sauvola)
matplotlib.rcParams['font.size'] = 9
image = page()
binary_global = image > threshold_otsu(image)
window_size = 25
thresh_niblack = threshold_niblack(image, window_size=window_size, k=0.8)
thresh_sauvola = threshold_sauvola(image, window_size=window_size)
binary_niblack = image > thresh_niblack
binary_sauvola = image > thresh_sauvola
plt.figure(figsize=(8, 7))
plt.subplot(2, 2, 1)
plt.imshow(image, cmap=plt.cm.gray)
plt.title('Original')
plt.axis('off')
plt.subplot(2, 2, 2)
plt.title('Global Threshold')
plt.imshow(binary_global, cmap=plt.cm.gray)
plt.axis('off')
plt.subplot(2, 2, 3)
plt.imshow(binary_niblack, cmap=plt.cm.gray)
plt.title('Niblack Threshold')
plt.axis('off')
plt.subplot(2, 2, 4)
plt.imshow(binary_sauvola, cmap=plt.cm.gray)
plt.title('Sauvola Threshold')
plt.axis('off')
plt.show()
结果图:
6.IntegralThreshold(主要用于文本检测)
使用方法: 运行下面网址的util.py文件
https://github.com/Liang-yc/IntegralThreshold
结果图:
来源:https://www.cnblogs.com/ttweixiao-IT-program/p/12091820.html
标签:python,图像,处理,二值,化
0
投稿
猜你喜欢
SQL的密码管理的六个危险判断
2012-01-05 19:07:21
Python enumerate索引迭代代码解析
2022-04-05 17:13:07
Django实现将views.py中的数据传递到前端html页面,并展示
2022-04-04 10:44:56
微信小程序中target和currentTarget的区别小结
2024-04-10 16:17:30
Vuex中如何getters动态获取state的值
2024-05-28 15:54:23
Go语言使用MySql的方法
2024-01-20 04:09:25
Python fileinput模块使用实例
2022-02-28 12:02:19
有关Python的22个编程技巧
2021-04-05 22:58:05
导入tensorflow时报错:cannot import name 'abs'的解决
2023-03-19 12:56:46
几款黑体的测试和介绍
2008-07-18 17:09:00
Python调用C语言的方法【基于ctypes模块】
2021-03-08 20:31:24
SpringSecurity从数据库中获取用户信息进行验证的案例详解
2024-01-23 17:16:25
pandas取出重复数据的方法
2021-03-23 09:12:52
PHP数组的基本操作及遍历数组的经典操作实例
2024-04-28 09:45:09
Python爬取用户观影数据并分析用户与电影之间的隐藏信息!
2022-09-09 23:19:47
每个分类取最新的几条的SQL实现代码
2024-01-27 04:44:20
python+tkinter+mysql做简单数据库查询界面
2024-01-19 21:13:20
详解mysql触发器trigger实例
2024-01-20 22:28:29
django-rest-framework解析请求参数过程详解
2023-03-26 18:18:00
ASP 中 DateDiff 函数详解
2007-09-19 12:00:00