站長資訊網(wǎng)
最全最豐富的資訊網(wǎng)站

Python圖像處理二值化方法實例云集

Python圖像處理二值化方法實例云集

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

相關(guān)學(xué)習(xí)推薦:python視頻教程

1. opencv 簡單閾值 cv2.threshold

2. opencv 自適應(yīng)閾值 cv2.adaptiveThreshold (自適應(yīng)閾值中計算閾值的方法有兩種: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 # 閾值一定要設(shè)為 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, 要注意的是它的參數(shù)是一維數(shù)組 # 所以這里使用了( numpy ) ravel 方法,將多維數(shù)組轉(zhuǎn)換成一維,也可以使用 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()

結(jié)果圖:

Python圖像處理二值化方法實例云集

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()

結(jié)果圖:

Python圖像處理二值化方法實例云集

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

使用方法: 運行下面網(wǎng)址的util.py文件

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

結(jié)果圖:

Python圖像處理二值化方法實例云集

贊(0)
分享到: 更多 (0)
網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號
国产精品成熟老妇女| 国产高清在线精品二区一| 国产精品永久免费视频| 日韩美女在线观看一区| 国产精品免费视频一区| 国内精品福利在线视频| 亚洲精品国产首次亮相| 992tv精品视频tv在线观看| 3d精品重口littleballerina| 久久精品九九热无码免贵| 国内午夜国产精品小视频| 精品一区二区三区色花堂| 国产精品1024视频| 亚洲国产精品碰碰| 九九免费精品视频在这里| 亚洲处破女AV日韩精品| 日韩无码系列综合区| 日韩一区二区在线观看| 国产在线观看91精品不卡| 国产伦精品一区二区三区视频小说| 精品极品三级久久久久| 国模精品视频一区二区三区| 久久久久久国产精品免费免费| 99久久国产亚洲综合精品| 99久久国产亚洲综合精品| 亚洲精品乱码久久久久蜜桃| 国产精品一区二区久久精品涩爱| 2020国产成人久久精品| 一级一级特黄女人精品毛片视频| 国产精品俺来也在线观看| 国产精品bbwbbwbbw| 亚洲精品乱码久久久久蜜桃| 久久精品无码中文字幕| 国产精品一在线观看| 麻豆国产精品入口免费观看| 日韩精品亚洲专区在线影视| 国产精品成人99一区无码| 国产精品久久精品视| 日韩大片在线永久免费观看网站 | 热久久美女精品天天吊色| 亚洲Av永久无码精品一区二区|