Python圖像閾值化處理及算法比對(duì)實(shí)例解析
圖像的二值化或閾值化(Binarization)旨在提取圖像中的目標(biāo)物體,將背景以及噪聲區(qū)分開(kāi)來(lái)。通常會(huì)設(shè)定一個(gè)閾值T,通過(guò)T將圖像的像素劃分為兩類(lèi):大于T的像素群和小于T的像素群。
灰度轉(zhuǎn)換處理后的圖像中,每個(gè)像素都只有一個(gè)灰度值,其大小表示明暗程度。二值化處理可以將圖像中的像素劃分為兩類(lèi)顏色,常用的二值化算法如公式1所示:
{Y=0,gray<TY=255,gray>=T{Y=0,gray<TY=255,gray>=T
當(dāng)灰度Gray小于閾值T時(shí),其像素設(shè)置為0,表示黑色;當(dāng)灰度Gray大于或等于閾值T時(shí),其Y值為255,表示白色。
Python OpenCV中提供了閾值函數(shù)threshold()實(shí)現(xiàn)二值化處理,其公式及參數(shù)如下圖所示:
retval, dst = cv2.threshold(src, thresh, maxval, type)
二進(jìn)制閾值化
該方法先要選定一個(gè)特定的閾值量,比如127
1) 大于等于127的像素點(diǎn)的灰度值設(shè)定為最大值
2) 灰度值小于127的像素點(diǎn)的灰度值設(shè)置為0
例如: 156->255 89->0
關(guān)鍵字為cv2.THRESH_BINARY,完整代碼如下
import cv2def test22(): src = cv2.imread('rose.jpg') # 灰度圖片轉(zhuǎn)換 GrayImage = cv2.cvtColor(src, cv2.COLOR_BGR2BGRA) # 二進(jìn)制閾值化處理 r, b = cv2.threshold(GrayImage, 127, 255, cv2.THRESH_BINARY) # 顯示圖像 cv2.imshow('src', src) cv2.imshow('result', b) if cv2.waitKey(0) == 27: cv2.destroyAllWindows()test22()
效果如下:
反二進(jìn)制閾值化
該方法與二進(jìn)制閾值化方法相似,先要選定一個(gè)特定的灰度值作為閾值,比如127
1) 大于127的像素點(diǎn)的灰度值設(shè)定為0
2) 小于該閾值的灰度值設(shè)定為255
例如:156->0 89->255
關(guān)鍵字為cv2.THRESH_BINARY_INV
代碼如下:
import cv2def test22(): src = cv2.imread('rose.jpg') # 灰度圖片轉(zhuǎn)換 GrayImage = cv2.cvtColor(src, cv2.COLOR_BGR2BGRA) # 二進(jìn)制閾值化處理 r, b = cv2.threshold(GrayImage, 127, 255, cv2.THRESH_BINARY_INV) # 顯示圖像 cv2.imshow('src', src) cv2.imshow('result', b) if cv2.waitKey(0) == 27: cv2.destroyAllWindows()test22()
效果如下:
截?cái)嚅撝祷?/b>
該方法需要選定一個(gè)閾值,圖像中大于該閾值的像素點(diǎn)被設(shè)定為該閾值,小于該閾值的保持不變。
1) 大于等于127像素點(diǎn)的灰度值設(shè)定為該閾值127
2) 小于該閾值的灰度值不變
例如: 163-> 127 89->89
關(guān)鍵字cv2.THRESH_TRUNC,完整代碼如下
import cv2def test22(): src = cv2.imread('rose.jpg') # 灰度圖片轉(zhuǎn)換 GrayImage = cv2.cvtColor(src, cv2.COLOR_BGR2BGRA) # 二進(jìn)制閾值化處理 r, b = cv2.threshold(GrayImage, 127, 255, cv2.THRESH_TRUNC) # 顯示圖像 cv2.imshow('src', src) cv2.imshow('result', b) if cv2.waitKey(0) == 27: cv2.destroyAllWindows()test22()
效果如下:
反閾值化為0
該方法先選定一個(gè)閾值,比如127
(1) 大于等于閾值127的像素點(diǎn)變?yōu)?(2) 小于該閾值的像素點(diǎn)值保持不變
例如: 128->0 89->89
關(guān)鍵字為cv2.THRESH_TOZERO_INV,完整代碼如下:
import cv2def test22(): src = cv2.imread('rose.jpg') # 灰度圖片轉(zhuǎn)換 GrayImage = cv2.cvtColor(src, cv2.COLOR_BGR2BGRA) # 二進(jìn)制閾值化處理 r, b = cv2.threshold(GrayImage, 127, 255, cv2.THRESH_TOZERO_INV) # 顯示圖像 cv2.imshow('src', src) cv2.imshow('result', b) if cv2.waitKey(0) == 27: cv2.destroyAllWindows()test22()
效果如下:
閾值為0
該方法先選定一個(gè)閾值,比如127
(1) 大于等于閾值127的像素點(diǎn),值保持不變
(2) 小于該閾值的像素點(diǎn)值設(shè)置為0
例如: 163->163 102->0
關(guān)鍵字為cv2.THRESH_TOZERO,完整代碼如下:
import cv2def test22(): src = cv2.imread('rose.jpg') # 灰度圖片轉(zhuǎn)換 GrayImage = cv2.cvtColor(src, cv2.COLOR_BGR2BGRA) # 二進(jìn)制閾值化處理 r, b = cv2.threshold(GrayImage, 127, 255, cv2.THRESH_TOZERO) # 顯示圖像 cv2.imshow('src', src) cv2.imshow('result', b) if cv2.waitKey(0) == 27: cv2.destroyAllWindows()test22()
效果如下:
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. ASP基礎(chǔ)入門(mén)第二篇(ASP基礎(chǔ)知識(shí))2. PHP中為什么使用file_get_contents("php://input")接收微信通知3. JSP出現(xiàn)中文亂碼問(wèn)題解決方法詳解4. 不使用XMLHttpRequest對(duì)象實(shí)現(xiàn)Ajax效果的方法小結(jié)5. ASP.NET MVC實(shí)現(xiàn)登錄后跳轉(zhuǎn)到原界面6. 怎樣打開(kāi)XML文件?xml文件如何打開(kāi)?7. TP5使用RabbitMQ實(shí)現(xiàn)消息隊(duì)列的項(xiàng)目實(shí)踐8. vue的路由動(dòng)畫(huà)切換頁(yè)面無(wú)法讀取meta值的bug記錄9. ThinkPHP6使用JWT+中間件實(shí)現(xiàn)Token驗(yàn)證實(shí)例詳解10. ASP.NET MVC限制同一個(gè)IP地址單位時(shí)間間隔內(nèi)的請(qǐng)求次數(shù)
