Python灰度變換中灰度切割分析實現(xiàn)
1. 介紹
灰度切割:增強特定范圍的對比度,突出圖像中特定范圍的亮度(灰度級分層也叫灰度切割)
實現(xiàn)灰度切割的方法有很多種,但基本的方法就兩種,其余的方法都是這兩個方法的變體
- 將感興趣范圍內(nèi)的灰度值全部映射成為一個值(如白色),將其余的灰度值顯示為另一個顏色(如黑色),產(chǎn)生一個二值圖像
- 將感興趣的灰度值變亮,保持其余的灰度值不變
對應(yīng)的映射函數(shù)為:

灰度切割的特殊使用:閾值處理
將感興趣的物體從背景中分離出來,也叫二值化處理,是第一種方法的變體
2. 灰度切割代碼實現(xiàn)
這次沒有采用for循環(huán)的方式去遍歷每個像素點
x[:,:] > a 代表x所有行所有列中大于a的點的位置會為True,再將結(jié)果傳入自身的坐標(biāo)中就能找到滿足兩個閾值中間的點,將這些點替換為255即可
import cv2
import numpy as np
def transform1(x):
a , b = 150 , 240 # 定義兩個閾值,中間部分變換為255
dst = x.copy()
dst[(x[:,:] >= a) & (x[:,:] <= b)] = 255 # 中間變換為255
dst[(x[:,:] < a) | (x[:,:] > b)] = 0 # 其余的變換為0
return dst
def transform2(x):
a , b = 150 , 240 # 定義兩個閾值,中間部分變換為255
dst = x.copy()
dst[(x[:,:] >= a) & (x[:,:] <= b)] = 255 # 中間變換255,其余的不變
return dst
gray = cv2.imread('./img.png',0)
dst1 = transform1(gray)
dst2 = transform2(gray)
cv2.imshow('img',np.hstack((gray,dst1,dst2)))
cv2.waitKey()
cv2.destroyAllWindows()輸出結(jié)果

3. 閾值處理
灰度切割的特殊使用是閾值處理,opencv中包含了threshold函數(shù)對圖像進行閾值處理
語法如下:retval,dst = cv2.threshold(src , thresh , maxval , type)
ret val(return value):處理時采用的閾值大小
dst :處理后的圖像
src : 處理前的圖像
maxval(max val):產(chǎn)生二值圖像后,閾值處理后輸出的值,另一個默認(rèn)是0。例如小于150的輸出0,其余的就是這個maxval(一般是255)
type : 閾值處理的類型,有如下的幾種類型
| type | 含義 |
| cv2.THRESH_BINARY | 二值化閾值處理:超出thresh,為255;否則為0 |
| cv2.THRESH_BINARY_INV | 反二值化閾值處理:超出thresh,為0;否則為255 |
| cv2.THRESH_TOZERO | 低于閾值零處理:低于thresh,為0;否則灰度值不變 |
| cv2.THRESH_TOZERO_INV | 超出閾值零處理:低于thresh,為255;否則為0 |
| cv2.THRESH_TRUNC(truncate截斷) | 截斷閾值處理:超過thresh,為thresh;否則不變 |
代碼:
import cv2
import numpy as np
a = np.arange(0,256).reshape(1,-1).astype(np.uint8) # 0-255
img = cv2.resize(a,(800,100),interpolation=cv2.INTER_AREA) # 創(chuàng)建漸變圖像
ret1,img1 = cv2.threshold(img,200,255,cv2.THRESH_BINARY) # 二值化閾值處理
ret2,img2 = cv2.threshold(img,200,255,cv2.THRESH_BINARY_INV) # 反二值化閾值處理
ret3,img3 = cv2.threshold(img,200,255,cv2.THRESH_TOZERO) # 低于閾值零處理
ret4,img4 = cv2.threshold(img,200,255,cv2.THRESH_TOZERO_INV) # 超出閾值零處理
ret5,img5 = cv2.threshold(img,200,255,cv2.THRESH_TRUNC) # 截斷閾值處理
cv2.imshow('img',np.vstack((img,img1,img2,img3,img4,img5)))
cv2.waitKey()
cv2.destroyAllWindows()處理結(jié)果:

到此這篇關(guān)于Python灰度變換中灰度切割分析實現(xiàn)的文章就介紹到這了,更多相關(guān)Python灰度切割內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python中matplotlib實現(xiàn)最小二乘法擬合的過程詳解
這篇文章主要給大家介紹了關(guān)于python中matplotlib實現(xiàn)最小二乘法擬合的相關(guān)資料,文中通過示例代碼詳細(xì)介紹了關(guān)于最小二乘法擬合直線和最小二乘法擬合曲線的實現(xiàn)過程,需要的朋友可以參考借鑒,下面來一起看看吧。2017-07-07
總結(jié)Python連接CS2000的詳細(xì)步驟
今天給大家?guī)淼氖顷P(guān)于Python的相關(guān)知識,文章圍繞著Python連接CS2000的詳細(xì)步驟展開,文中有非常詳細(xì)的介紹及代碼示例,需要的朋友可以參考下2021-06-06
Python通過30秒就能學(xué)會的漂亮短程序代碼(過程全解)
這篇文章主要介紹了Python之30秒就能學(xué)會的漂亮短程序代碼,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-10-10
Python實現(xiàn)數(shù)據(jù)結(jié)構(gòu)線性鏈表(單鏈表)算法示例
這篇文章主要介紹了Python實現(xiàn)數(shù)據(jù)結(jié)構(gòu)線性鏈表(單鏈表)算法,結(jié)合實例形式分析了Python單鏈表的定義、節(jié)點插入、刪除、打印等相關(guān)操作技巧,需要的朋友可以參考下2019-05-05

