欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python下opencv圖像閾值處理的使用筆記

 更新時間:2019年08月04日 09:45:58   作者:on2way  
這篇文章主要介紹了Python下opencv圖像閾值處理的使用筆記,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

圖像的閾值處理一般使得圖像的像素值更單一、圖像更簡單。閾值可以分為全局性質(zhì)的閾值,也可以分為局部性質(zhì)的閾值,可以是單閾值的也可以是多閾值的。當(dāng)然閾值越多是越復(fù)雜的。下面將介紹opencv下的三種閾值方法。

(一)簡單閾值

簡單閾值當(dāng)然是最簡單,選取一個全局閾值,然后就把整幅圖像分成了非黑即白的二值圖像了。函數(shù)為cv2.threshold()
這個函數(shù)有四個參數(shù),第一個原圖像,第二個進(jìn)行分類的閾值,第三個是高于(低于)閾值時賦予的新值,第四個是一個方法選擇參數(shù),常用的有:

  • cv2.THRESH_BINARY(黑白二值)
  • cv2.THRESH_BINARY_INV(黑白二值反轉(zhuǎn))
  • cv2.THRESH_TRUNC (得到的圖像為多像素值)
  • cv2.THRESH_TOZERO
  • cv2.THRESH_TOZERO_INV

該函數(shù)有兩個返回值,第一個retVal(得到的閾值值(在后面一個方法中會用到)),第二個就是閾值化后的圖像。
一個實例如下:

import cv2
import matplotlib.pyplot as plt

img = cv2.imread('flower.jpg',0) #直接讀為灰度圖像
ret,thresh1 = cv2.threshold(img,127,255,cv2.THRESH_BINARY)
ret,thresh2 = cv2.threshold(img,127,255,cv2.THRESH_BINARY_INV)
ret,thresh3 = cv2.threshold(img,127,255,cv2.THRESH_TRUNC)
ret,thresh4 = cv2.threshold(img,127,255,cv2.THRESH_TOZERO)
ret,thresh5 = cv2.threshold(img,127,255,cv2.THRESH_TOZERO_INV)
titles = ['img','BINARY','BINARY_INV','TRUNC','TOZERO','TOZERO_INV']
images = [img,thresh1,thresh2,thresh3,thresh4,thresh5]
for i in range(6):
 plt.subplot(2,3,i+1),plt.imshow(images[i],'gray')
 plt.title(titles[i])
 plt.xticks([]),plt.yticks([])
plt.show()

這里寫圖片描述 

可以看到這里把閾值設(shè)置成了127,對于BINARY方法,當(dāng)圖像中的灰度值大于127的重置像素值為255.

(二)自適應(yīng)閾值:

前面看到簡單閾值是一種全局性的閾值,只需要規(guī)定一個閾值值,整個圖像都和這個閾值比較。而自適應(yīng)閾值可以看成一種局部性的閾值,通過規(guī)定一個區(qū)域大小,比較這個點與區(qū)域大小里面像素點的平均值(或者其他特征)的大小關(guān)系確定這個像素點是屬于黑或者白(如果是二值情況)。使用的函數(shù)為:cv2.adaptiveThreshold()
該函數(shù)需要填6個參數(shù):

  1. 第一個原始圖像
  2. 第二個像素值上限
  3. 第三個自適應(yīng)方法Adaptive Method:
    1. — cv2.ADAPTIVE_THRESH_MEAN_C :領(lǐng)域內(nèi)均值
    2. —cv2.ADAPTIVE_THRESH_GAUSSIAN_C :領(lǐng)域內(nèi)像素點加權(quán)和,權(quán) 重為一個高斯窗口
  4. 第四個值的賦值方法:只有cv2.THRESH_BINARY 和cv2.THRESH_BINARY_INV
  5. 第五個Block size:規(guī)定領(lǐng)域大?。ㄒ粋€正方形的領(lǐng)域)
  6. 第六個常數(shù)C,閾值等于均值或者加權(quán)值減去這個常數(shù)(為0相當(dāng)于閾值 就是求得領(lǐng)域內(nèi)均值或者加權(quán)值)

這種方法理論上得到的效果更好,相當(dāng)于在動態(tài)自適應(yīng)的調(diào)整屬于自己像素點的閾值,而不是整幅圖像都用一個閾值。

一個實例如下:

mport cv2
import matplotlib.pyplot as plt

img = cv2.imread('flower.jpg',0) #直接讀為灰度圖像
ret,th1 = cv2.threshold(img,127,255,cv2.THRESH_BINARY)
th2 = cv2.adaptiveThreshold(img,255,cv2.ADAPTIVE_THRESH_MEAN_C,\
cv2.THRESH_BINARY,11,2) #換行符號 \
th3 = cv2.adaptiveThreshold(img,255,cv2.ADAPTIVE_THRESH_GAUSSIAN_C,\
cv2.THRESH_BINARY,11,2) #換行符號 \
images = [img,th1,th2,th3]
plt.figure()
for i in xrange(4):
 plt.subplot(2,2,i+1),plt.imshow(images[i],'gray')
plt.show()

這里寫圖片描述 

可以看到上述窗口大小使用的為11,當(dāng)窗口越小的時候,得到的圖像越細(xì)。想想一下,如果把窗口設(shè)置足夠大以后(不能超過圖像大?。?,那么得到的結(jié)果可能就和第二幅圖像的相同了。

(三)Otsu's二值化

我們前面說到,cv2.threshold函數(shù)是有兩個返回值的,前面一直用的第二個返回值,也就是閾值處理后的圖像,那么第一個返回值(得到圖像的閾值)將會在這里用到。

前面對于閾值的處理上,我們選擇的閾值都是127,那么實際情況下,怎么去選擇這個127呢?有的圖像可能閾值不是127得到的效果更好。那么這里我們需要算法自己去尋找到一個閾值,而Otsu's就可以自己找到一個認(rèn)為最好的閾值。并且Otsu's非常適合于圖像灰度直方圖具有雙峰的情況,他會在雙峰之間找到一個值作為閾值,對于非雙峰圖像,可能并不是很好用。那么經(jīng)過Otsu's得到的那個閾值就是函數(shù)cv2.threshold的第一個參數(shù)了。因為Otsu's方法會產(chǎn)生一個閾值,那么函數(shù)cv2.threshold的的第二個參數(shù)(設(shè)置閾值)就是0了,并且在cv2.threshold的方法參數(shù)中還得加上語句cv2.THRESH_OTSU。那么什么是雙峰圖像(只能是灰度圖像才有),就是圖像的灰度統(tǒng)計圖中可以明顯看出只有兩個波峰,比如下面一個圖的灰度直方圖就可以是雙峰圖:

這里寫圖片描述 

好了現(xiàn)在對這個圖進(jìn)行Otsu's閾值處理就非常的好,通過函數(shù)cv2.threshold會自動找到一個介于兩波峰之間的閾值。一個實例如下:

import cv2
import matplotlib.pyplot as plt

img = cv2.imread('finger.jpg',0) #直接讀為灰度圖像
#簡單濾波
ret1,th1 = cv2.threshold(img,127,255,cv2.THRESH_BINARY)
#Otsu 濾波
ret2,th2 = cv2.threshold(img,0,255,cv2.THRESH_BINARY+cv2.THRESH_OTSU)
print ret2
plt.figure()
plt.subplot(221),plt.imshow(img,'gray')
plt.subplot(222),plt.hist(img.ravel(),256)#.ravel方法將矩陣轉(zhuǎn)化為一維
plt.subplot(223),plt.imshow(th1,'gray')
plt.subplot(224),plt.imshow(th2,'gray')

這里寫圖片描述 

print ret2 得到的結(jié)果為122??梢钥闯鏊坪鮾蓚€結(jié)果并沒有很明顯差別(素材也不太好弄~_~!),主要是兩個閾值(127與122)太相近了,如果這兩個隔得很遠(yuǎn)那么會很明顯的。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 利用ImageAI庫只需幾行python代碼實現(xiàn)目標(biāo)檢測

    利用ImageAI庫只需幾行python代碼實現(xiàn)目標(biāo)檢測

    這篇文章主要介紹了利用ImageAI庫只需幾行python代碼超簡實現(xiàn)目標(biāo)檢測功能,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-08-08
  • opencv python簡易文檔之圖片基本操作指南

    opencv python簡易文檔之圖片基本操作指南

    OpenCv除了可以獲取圖像之外,還可以對圖像進(jìn)行一下處理操作,下面這篇文章主要給大家介紹了關(guān)于opencv python簡易文檔之圖片基本操作的相關(guān)資料,需要的朋友可以參考下
    2021-08-08
  • Python字典fromkeys()方法使用代碼實例

    Python字典fromkeys()方法使用代碼實例

    這篇文章主要介紹了Python字典fromkeys()方法使用代碼實例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-07-07
  • python中四舍五入的正確打開方式

    python中四舍五入的正確打開方式

    這篇文章主要介紹了python中四舍五入的正確打開方式,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • Python離線安裝第三方庫詳細(xì)操作流程

    Python離線安裝第三方庫詳細(xì)操作流程

    在使用Python開發(fā)過程中,我們經(jīng)常需要使用各種第三方庫來擴(kuò)展Python的功能,這篇文章主要給大家介紹了關(guān)于Python離線安裝第三方庫的相關(guān)資料,需要的朋友可以參考下
    2023-11-11
  • Python解決八皇后問題示例

    Python解決八皇后問題示例

    這篇文章主要介紹了Python解決八皇后問題,簡單描述了八皇后問題的原理并結(jié)合實例形式分析了Python基于遞歸算法解決八皇后問題的相關(guān)操作技巧,需要的朋友可以參考下
    2018-04-04
  • win10下安裝Anaconda的教程(python環(huán)境+jupyter_notebook)

    win10下安裝Anaconda的教程(python環(huán)境+jupyter_notebook)

    Anaconda指的是一個開源的Python發(fā)行版本,其包含了conda、Python等180多個科學(xué)包及其依賴項。這篇文章主要介紹了win10下安裝Anaconda(python環(huán)境+jupyter_notebook),需要的朋友可以參考下
    2019-10-10
  • 使用python實現(xiàn)時間序列白噪聲檢驗方式

    使用python實現(xiàn)時間序列白噪聲檢驗方式

    這篇文章主要介紹了使用python實現(xiàn)時間序列白噪聲檢驗方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-06-06
  • Python利用蒙特卡羅模擬期權(quán)定價

    Python利用蒙特卡羅模擬期權(quán)定價

    期權(quán)是一種合約,它賦予買方在未來某個時間點以特定價格買賣資產(chǎn)的權(quán)利。本文將利用蒙特卡羅模擬期權(quán)定價,感興趣的小伙伴可以了解一下
    2022-04-04
  • 利用python?OpenCV去除視頻水印

    利用python?OpenCV去除視頻水印

    這篇文章主要介紹了利用python?OpenCV去除視頻水印,下面我們將利用視頻的某一幀將圖片的一些污點去掉,代碼先從視頻中導(dǎo)出一幀圖片,然后統(tǒng)計需要刪除按鈕的坐標(biāo)位置,然后再對視頻中的每一幀圖像做處理的函數(shù),下面操作過程需要的小伙伴可以參考一下
    2022-02-02

最新評論