溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Python?OpenCV閾值處理的示例分析

發(fā)布時(shí)間:2022-02-08 14:52:02 來源:億速云 閱讀:152 作者:小新 欄目:開發(fā)技術(shù)

小編給大家分享一下Python OpenCV閾值處理的示例分析,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

前言

圖像分割是許多計(jì)算機(jī)視覺應(yīng)用中的關(guān)鍵處理步驟,通常用于將圖像劃分為不同的區(qū)域,這些區(qū)域常常對(duì)應(yīng)于真實(shí)世界的對(duì)象。因此,圖像分割是圖像識(shí)別和內(nèi)容分析的重要步驟。圖像閾值是一種簡單、有效的圖像分割方法,其中像素根據(jù)其強(qiáng)度值進(jìn)行分區(qū)。在本文中,將介紹 OpenCV 所提供的主要閾值技術(shù),可以將這些技術(shù)用作計(jì)算機(jī)視覺應(yīng)用程序中圖像分割的關(guān)鍵部分。

閾值技術(shù)簡介

閾值處理是一種簡單、有效的將圖像劃分為前景和背景的方法。圖像分割通常用于根據(jù)對(duì)象的某些屬性(例如,顏色、邊緣或直方圖)從背景中提取對(duì)象。最簡單的閾值方法會(huì)利用預(yù)定義常數(shù)(閾值),如果像素強(qiáng)度小于閾值,則用黑色像素替換,如果像素強(qiáng)度大于閾值,則用白色像素替換。OpenCV 提供了 cv2.threshold() 函數(shù)來對(duì)圖像進(jìn)行閾值處理。

為了測試 cv2.threshold() 函數(shù),首次創(chuàng)建測試圖像,其包含一些填充了不同的灰色調(diào)的大小相同的區(qū)域,利用 build_sample_image() 函數(shù)構(gòu)建此測試圖像:

def build_sample_image():
    """創(chuàng)建填充了不同的灰色調(diào)的大小相同的區(qū)域,作為測試圖像"""
    # 定義不同區(qū)域
    tones = np.arange(start=50, stop=300, step=50)
    # 初始化
    result = np.zeros((50, 50, 3), dtype="uint8")

    for tone in tones:
        img = np.ones((50, 50, 3), dtype="uint8") * tone
        # 沿軸連接數(shù)組
        result = np.concatenate((result, img), axis=1)
    return result

接下來將使用不同的預(yù)定義閾值: 0 、 50 、 100 、 150 、 200 和 250 調(diào)用 cv2.threshold() 函數(shù),以查看不同預(yù)定義閾值對(duì)閾值圖像影響。例如,使用閾值 thresh = 50 對(duì)圖像進(jìn)行閾值處理:

ret1, thresh2 = cv2.threshold(gray_image, 50, 255, cv2.THRESH_BINARY)

其中,thresh2 是僅包含黑白色的閾值圖像。源圖像 gray_image 中灰色強(qiáng)度小于 50 的像素為黑色,強(qiáng)度大于 50 的像素為白色。

使用多個(gè)不同閾值對(duì)圖像進(jìn)行閾值處理:

# 可視化函數(shù)
def show_img_with_matplotlib(color_img, title, pos):
    img_RGB = color_img[:, :, ::-1]

    ax = plt.subplot(7, 1, pos)
    plt.imshow(img_RGB)
    plt.title(title, fontsize=8)
    plt.axis('off')
# 使用 build_sample_image() 函數(shù)構(gòu)建測試圖像
image = build_sample_image()
gray_image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
for i in range(6):
    # 使用多個(gè)不同閾值對(duì)圖像進(jìn)行閾值處理
    ret, thresh = cv2.threshold(gray_image, 50 * i, 255, cv2.THRESH_BINARY)
    # 可視化
    show_img_with_matplotlib(cv2.cvtColor(thresh, cv2.COLOR_GRAY2BGR), "threshold = {}".format(i * 50), i + 2)
# 可視化測試圖像
show_img_with_matplotlib(cv2.cvtColor(gray_image, cv2.COLOR_GRAY2BGR), "img with tones of gray - left to right: (0,50,100,150,200,250)", 1)
# 圖像進(jìn)行閾值處理后,常見的輸出是黑白圖像
# 因此,為了更好的可視化效果,修改背景顏色
fig.patch.set_facecolor('silver')

plt.show()

Python?OpenCV閾值處理的示例分析

從上圖可以看出,根據(jù)閾值和樣本圖像灰度值的不同,閾值處理后生成的黑白圖像的變化情況。

簡單的閾值技術(shù)

上一節(jié)中,我們已經(jīng)簡單介紹過了 OpenCV 中提供的簡單閾值處理函數(shù)——cv2.threshold(),該函數(shù)用法如下:

cv2.threshold(src, thresh, maxval, type, dst=None) -> retval, dst

cv2.threshold() 函數(shù)對(duì) src 輸入數(shù)組(可以為單通道或多通道圖像)應(yīng)用預(yù)定義常數(shù) thresh 設(shè)置的閾值;type 參數(shù)用于設(shè)置閾值類型,閾值類型的可選值如下:cv2.THRESH_BINARYcv2.THRESH_BINARY_INV、cv2.THRESH_TRUNC、cv2.THRESH_TOZEROcv2.THRESH_TOZERO_INV、cv2.THRESH_OTSUcv2.THRESH_TRIANGLE。

maxval 參數(shù)用于設(shè)置最大值,其僅在閾值類型為 cv2.THRESH_BINARYcv2.THRESH_BINARY_INV 時(shí)有效;需要注意的是,在閾值類型為 cv2.THRESH_OTSUcv2.THRESH_TRIANGLE 時(shí),輸入圖像 src 應(yīng)為為單通道。

閾值類型

為了更好的了解閾值操作的不同類型,接下來給出每種閾值類型的具體公式。符號(hào)說明:src 是源(原始)圖像,dst 對(duì)應(yīng)于閾值化后的目標(biāo)(結(jié)果)圖像,因此,src(x, y) 對(duì)應(yīng)于源圖像像素 (x, y) 處的強(qiáng)度,而 dst(x, y) 對(duì)應(yīng)于目標(biāo)圖像像素 (x, y) 處的強(qiáng)度。

閾值類型 cv2.THRESH_BINARY 公式如下:

Python?OpenCV閾值處理的示例分析

其表示,如果像素 src(x, y) 的強(qiáng)度高于 thresh,則目標(biāo)圖像像素強(qiáng)度 dst(x,y) 將被設(shè)為 maxval;否則,設(shè)為 0。

閾值類型 cv2.THRESH_BINARY_INV 公式如下:

Python?OpenCV閾值處理的示例分析

其表示,如果像素 src(x, y) 的強(qiáng)度高于 thresh,則目標(biāo)圖像像素強(qiáng)度 dst(x,y) 將被設(shè)為 0;否則,設(shè)為 maxval。

閾值類型 cv2.THRESH_TRUNC 公式如下:

Python?OpenCV閾值處理的示例分析

其表示,如果像素 src(x, y) 的強(qiáng)度高于 thresh,則目標(biāo)圖像像素強(qiáng)度設(shè)置為 threshold;否則,設(shè)為 src(x, y)。

閾值類型 cv2.THRESH_TOZERO 公式如下:

Python?OpenCV閾值處理的示例分析

其表示,如果像素 src(x, y) 的強(qiáng)度高于 thresh,則目標(biāo)圖像像素值將設(shè)置為 src(x, y);否則,設(shè)置為 0 。

閾值類型 cv2.THRESH_TOZERO_INV 公式如下:

Python?OpenCV閾值處理的示例分析

其表示,如果像素 src(x, y) 的強(qiáng)度大于 thresh,則目標(biāo)圖像像素值將設(shè)置為 0;否則,設(shè)置為 src(x, y)。

cv2.THRESH_OTSUcv2.THRESH_TRIANGLE 屬于特殊的閾值類型,它們可以與上述閾值類型( cv2.THRESH_BINARY、cv2.THRESH_BINARY_INV、cv2.THRESH_TRUNC、cv2.THRESH_TOZEROcv2.THRESH_TOZERO_INV)進(jìn)行組合。組合后,閾值處理函數(shù) cv2.threshold() 將只能處理單通道圖像,且計(jì)算并返回最佳閾值,而非指定閾值。

接下來使用不同閾值類型對(duì)同樣的測試圖像進(jìn)行閾值處理,觀察不同閾值處理效果:

ret1, thresh2 = cv2.threshold(gray_image, 100, 255, cv2.THRESH_BINARY)
ret2, thresh3 = cv2.threshold(gray_image, 100, 220, cv2.THRESH_BINARY)
ret3, thresh4 = cv2.threshold(gray_image, 100, 255, cv2.THRESH_BINARY_INV)
ret4, thresh5 = cv2.threshold(gray_image, 100, 220, cv2.THRESH_BINARY_INV)
ret5, thresh6 = cv2.threshold(gray_image, 100, 255, cv2.THRESH_TRUNC)
ret6, thresh7 = cv2.threshold(gray_image, 100, 255, cv2.THRESH_TOZERO)
ret7, thresh7 = cv2.threshold(gray_image,100,255, cv2.THRESH_TOZERO_INV)
# 可視化
show_img_with_matplotlib(cv2.cvtColor(thresh2, cv2.COLOR_GRAY2BGR), "THRESH_BINARY - thresh = 100 & maxValue = 255", 2)
show_img_with_matplotlib(cv2.cvtColor(thresh3, cv2.COLOR_GRAY2BGR), "THRESH_BINARY - thresh = 100 & maxValue = 220", 3)
show_img_with_matplotlib(cv2.cvtColor(thresh4, cv2.COLOR_GRAY2BGR), "THRESH_BINARY_INV - thresh = 100", 4)
# 其他圖像可視化方法類似,不再贅述
# ...

Python?OpenCV閾值處理的示例分析

如上圖所示,maxval 參數(shù)僅在使用 cv2.THRESH_BINARYcv2.THRESH_BINARY_INV 閾值類型時(shí)有效,上例中將 cv2.THRESH_BINARYcv2.THRESH_BINARY_INV 類型的 maxval 值設(shè)置為 255220,以便查看閾值圖像在這兩種情況下的變化情況。

簡單閾值技術(shù)的實(shí)際應(yīng)用

了解 cv2.threshold() 不同參數(shù)的工作原理后,我們將 cv2.threshold() 應(yīng)用于真實(shí)圖像,并使用不同的閾值:

# 加載圖像
image = cv2.imread('example.png')
gray_image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)

# 繪制灰度圖像
show_img_with_matplotlib(cv2.cvtColor(gray_image, cv2.COLOR_GRAY2BGR), "img", 1)

# 使用不同的閾值調(diào)用 cv2.threshold() 并進(jìn)行可視化
for i in range(8):
    ret, thresh = cv2.threshold(gray_image, 130 + i * 10, 255, cv2.THRESH_BINARY)
    show_img_with_matplotlib(cv2.cvtColor(thresh, cv2.COLOR_GRAY2BGR), "threshold = {}".format(130 + i * 10), i + 2)

Python?OpenCV閾值處理的示例分析

看完了這篇文章,相信你對(duì)“Python OpenCV閾值處理的示例分析”有了一定的了解,如果想了解更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI