色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

Python圖像處理二值化方法實例匯總

瀏覽:4日期:2022-07-16 13:17:11

在用python進行圖像處理時,二值化是非常重要的一步,現總結了自己遇到過的6種 圖像二值化的方法(當然這個絕對不是全部的二值化方法,若發現新的方法會繼續新增)。

1. opencv 簡單閾值 cv2.threshold

2. opencv 自適應閾值 cv2.adaptiveThreshold (自適應閾值中計算閾值的方法有兩種:mean_c 和 guassian_c ,可以嘗試用下哪種效果好)

3. Otsu’s 二值化

例子:

import cv2import numpy as npfrom matplotlib import pyplot as pltimg = cv2.imread(’scratch.png’, 0)# global thresholdingret1, th1 = cv2.threshold(img, 127, 255, cv2.THRESH_BINARY)# Otsu’s thresholdingth2 = 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 histogramsimages = [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()

結果圖:

Python圖像處理二值化方法實例匯總

4. skimage niblack閾值

5. skimage sauvola閾值 (主要用于文本檢測)

例子:

https://scikit-image.org/docs/dev/auto_examples/segmentation/plot_niblack_sauvola.html

import matplotlibimport matplotlib.pyplot as pltfrom skimage.data import pagefrom skimage.filters import (threshold_otsu, threshold_niblack, threshold_sauvola)matplotlib.rcParams[’font.size’] = 9image = page()binary_global = image > threshold_otsu(image)window_size = 25thresh_niblack = threshold_niblack(image, window_size=window_size, k=0.8)thresh_sauvola = threshold_sauvola(image, window_size=window_size)binary_niblack = image > thresh_niblackbinary_sauvola = image > thresh_sauvolaplt.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()

結果圖:

Python圖像處理二值化方法實例匯總

6.IntegralThreshold(主要用于文本檢測)

使用方法: 運行下面網址的util.py文件

https://github.com/Liang-yc/IntegralThreshold

結果圖:

Python圖像處理二值化方法實例匯總

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 青青青免费手机版视频在线观看 | 亚洲欧美日韩国产一区二区精品 | 久久性久久性久久久爽 | 日本三级成人中文字幕乱码 | 欧美一级特黄一片免费 | 亚洲精品久久久久久久网站 | 寡妇一级a毛片免费播放 | 欧美色欧美亚洲高清在线视频 | 日韩高清欧美 | 我要看一级大片 | 欧美午夜视频一区二区三区 | 日韩三级在线播放 | 欧美一级在线观看视频 | 久草视频精品在线 | 亚洲精品中文字幕一区 | 色拍拍在精品视频69影院在线 | 国产女人自拍 | 亚洲天堂男人 | 国产一区二 | 亚洲欧美精品 | 亚洲精品国产精品国自产 | 91精品国产综合久久香蕉 | 欧美一级专区免费大片俄罗斯 | 精品一区二区三区免费毛片爱 | 92精品国产自产在线观看 | 91精品国产91久久久久青草 | 精品老司机在线视频香蕉 | 日韩99| 毛片看看| 91精品国产高清久久久久久91 | 国产手机在线精品 | 成人男女网18免费0 成人男女网18免费看 | 免费成人高清 | 996热这里有精品青青草原 | 精品久久久久久久久久香蕉 | 普通话对白国产情侣自啪 | 亚洲精品一级一区二区三区 | 亚洲天堂网在线视频 | 免费一区二区三区久久 | 国产a高清| 亚洲精品一区二区手机在线 |