python亲密度_Python OpenCV 图像2D直方图,取经之旅第 25 天
Python OpenCV 365 天學(xué)習(xí)計劃,與橡皮擦一起進入圖像領(lǐng)域吧。
基礎(chǔ)知識鋪墊
在之前的博客中,我們獲取圖像直方圖的方式都是獲取一維直方圖,簡單說就是只獲取一個通道的特征,例如灰度,B 通道,R 通道。
今天要學(xué)習(xí)的第一個內(nèi)容是二維直方圖,也叫做 2D 直方圖,涉及兩個特征,其中一個是像素的色調(diào),另一個是飽和度。
有這兩個值你應(yīng)該能猜到,需要提前將圖像轉(zhuǎn)換成 HSV 格式。
cv2.calcHist 函數(shù)
計算 2D 直方圖,使用的函數(shù)與之前學(xué)習(xí)的一樣,也是 cv2.calcHist 函數(shù)。
如果獲取彩色直方圖,需要提前將 BGR 轉(zhuǎn)換成 HSV。
函數(shù)原型
cv2.calcHist(images, channels, mask, histSize,ranges[, hist[,accumulate]])
參數(shù)說明:
images: 原圖像(圖像格式為 uint8 或 float32),當(dāng)傳入函數(shù)時應(yīng)該用中括號 []括起來,例如:[img];
channels:[0,1] 需要同時處理 H 和 S 兩個通道;
bins:[180,256] Hue 通道為 180,S 通道為 256;
range:[0,180,0,256],Hue 的取值范圍在 0 到 180,飽和度 S 的取值范圍在 0 到 256。
測試代碼如下:
import cv2 as cv
import numpy as np
from matplotlib import pyplot as plt
def create_2d_hist(image):
hsv = cv.cvtColor(image, cv.COLOR_BGR2HSV)
hist = cv.calcHist([hsv], [0, 1], None, [180, 256], [0, 180, 0, 256])
return hist
img = cv.imread('2.jpg')
hsv = cv.cvtColor(img, cv.COLOR_BGR2HSV)
plt.plot(create_2d_hist(img))
plt.show()
運行效果如下圖所示,可以看到 2D 直方圖了。
在檢索資料的時候,還學(xué)習(xí)到如下展示直方圖的方式,不過效果不如線條的好。
plt.imshow(hist,interpolation = 'nearest')
numpy 中的 2D 直方圖
numpy 庫也為 2D 直方圖提供了一個函數(shù),np.histogram2d函數(shù)。
函數(shù)原型
由于之前已經(jīng)學(xué)習(xí)過 np.histogram 函數(shù)了,學(xué)習(xí)這個 2D 直方圖函數(shù)理解上就比較容易了。
histogram2d(x, y, bins=10, range=None, normed=None, weights=None, density=None)
參數(shù)說明:
x, y:H 通道與 S 通道;
bins:bins 數(shù)目;
range:H 和 S 的范圍。
參數(shù)更細致的說明可以通過 help(np.histogram2d) 查閱。
測試代碼如下:
運行之后,發(fā)現(xiàn)結(jié)果如下圖所示。
上表紅線為橡皮擦標記內(nèi)容,兩個表進行對應(yīng)。H=25,S=20 還有 H=100-150,S=120-100,可以得出黃色,藍色,紫色區(qū)域高值,對應(yīng)的原圖上,結(jié)論差不多。
原圖如下
官方手冊可以閱讀:點擊跳轉(zhuǎn)
橡皮擦的小節(jié)
希望今天的一個小時,你有所收獲,我們下篇博客見~
相關(guān)閱讀
今天是持續(xù)寫作的第 67 / 100 天。
如果你有想要交流的想法、技術(shù),歡迎在評論區(qū)留言。
如果你想跟博主建立親密關(guān)系,可以關(guān)注博主,或者關(guān)注博主公眾號 “非本科程序員”,了解一個非本科程序員是如何成長的。
博主 ID:夢想橡皮擦,希望大家點贊、評論、收藏
本文同步分享在 博客“夢想橡皮擦”(CSDN)。
如有侵權(quán),請聯(lián)系 support@oschina.cn 刪除。
本文參與“OSC源創(chuàng)計劃”,歡迎正在閱讀的你也加入,一起分享。
總結(jié)
以上是生活随笔為你收集整理的python亲密度_Python OpenCV 图像2D直方图,取经之旅第 25 天的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 北京火车站到北京环球影城怎么去
- 下一篇: 海信75E5G和创维75G22哪个好?