国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

python下對hsv顏色空間進行量化操作

瀏覽:2日期:2022-07-22 18:47:18

更新:優(yōu)化了代碼,理由numpy的ufunc函數(shù)功能替換了之前的雙重for循環(huán),測試圖片大小為692*1024*3,優(yōu)化前運行時間為6.9s,優(yōu)化后為0.8s。

由于工作需要,需要計算顏色直方圖來提取顏色特征,但若不將顏色空間進行量化,則直方圖矢量維數(shù)過高,不便于使用。但是看了opencv API后并未發(fā)現(xiàn)提供了相關函數(shù)能夠在計算顏色直方圖的同時進行量化,因此這部分功能只能自己實現(xiàn)。下面分為兩個部分進行介紹:

一、顏色空間量化表

由于RGB模型不夠直觀,不符合人類視覺習慣,因此在進行顏色特征提取前,需要將照片從RGB顏色模型轉(zhuǎn)換為更符合人類視覺的HSV模型。在提取顏色特征時,最常用的方法之一為顏色直方圖法,但一張圖片中出現(xiàn)的顏色一般特別多,導致直方圖矢量的維數(shù)較高,因此需要對HSV空間進行量化。根據(jù)人眼對顏色的感知特性,采用較為常用的量化方法,即按照如下對應關系進行量化:

python下對hsv顏色空間進行量化操作

基于上述量化表,將各顏色分量按照下述公式合成為72維一維矢量:python下對hsv顏色空間進行量化操作

二、量化代碼

代碼使用純python寫成,效率偏低,處理388*500像素的照片用時1.45秒。在quantilize函數(shù)中,未使用if-else判斷語句,因此至少節(jié)省了1/3的時間。但這個速度顯然是無法令人滿意的,用C++效率應該會更高點。如果有人有更好的想法,歡迎在下方評論交流。

#-*-coding:utf-8-*-import cv2import numpy as npfrom datetime import datetimefrom matplotlib import pyplot as pltdef colors(imagepath): img = cv2.imread(imagepath) hsv = cv2.cvtColor(img, cv2.COLOR_RGB2HSV) nhsv = np.zeros(hsv.shape[:2], dtype=np.uint8) t2 = datetime.now() for i in range(hsv.shape[0]): for j in range(hsv.shape[1]): nhsv[i][j] = quantilize(hsv[i][j]) print datetime.now() - t2 hist = cv2.calcHist([nhsv], [0], None, [72], [0,71]) # 40x faster than np.histogramfaster than np.histogram plt.plot(hist,color = ’r’) plt.xlim([0, 72]) plt.show()def quantilize(value): ’’’hsv直方圖量化 value : [21, 144, 23] h, s, v opencv中,h-[0,180], s-[0,255], v-[0,255] ’’’ # value[0] = value[0] * 2 hlist = [20, 40, 75, 155, 190, 270, 290, 316, 360] svlist = [21, 178, 255] for i in range(len(hlist)): if value[0] <= hlist[i]: h = i % 8 break for i in range(len(svlist)): if value[1] <= svlist[i]: s = i break for i in range(len(svlist)): if value[2] <= svlist[i]: v = i break return 9 * h + 3 * s + v

以上,歡迎批評交流~

三、更新

#-*-coding:utf-8-*-import cv2import numpy as npfrom datetime import datetimefrom matplotlib import pyplot as plthlist = [20, 40, 75, 155, 190, 270, 290, 316, 360]svlist = [21, 178, 255]def quantilize(h, s, v): ’’’hsv直方圖量化’’’ # value : [21, 144, 23] h, s, v h = h * 2 for i in range(len(hlist)): if h <= hlist[i]: h = i % 8 break for i in range(len(svlist)): if s <= svlist[i]: s = i break for i in range(len(svlist)): if v <= svlist[i]: v = i break return 9 * h + 3 * s + vquantilize_ufunc = np.frompyfunc(quantilize, 3, 1) # 自定義ufunc函數(shù),即將quantilize函數(shù)轉(zhuǎn)化為ufunc函數(shù),其輸入?yún)?shù)為3個,輸出參數(shù)為1個。def colors(img): hsv = cv2.cvtColor(img, cv2.COLOR_RGB2HSV) nhsv = quantilize_ufunc(hsv[:,:,0], hsv[:,:,1], hsv[:,:,2]).astype(np.uint8) # 由于frompyfunc函數(shù)返回結(jié)果為對象,所以需要轉(zhuǎn)換類型 hist = cv2.calcHist([nhsv], [0], None, [72], [0,71]) # 40x faster than np.histogram hist = hist.reshape(1, hist.shape[0]).astype(np.int32).tolist()[0] return histif __name__ == ’__main__’: img_path = path + ’test.jpg’ img = cv2.imread(img_path) colors(img)

結(jié)果

[0, 11, 31490, 100, 3, 32685, 0, 28, 313, 0, 0, 3268, 31, 0, 558364, 6, 1, 441, 0, 0, 2301, 92, 0, 34056, 0, 1, 396, 0, 0, 2682, 84, 5, 712, 0, 137, 55, 0, 0, 1215, 20, 2, 224, 0, 3, 0, 0, 0, 13838, 56, 0, 23474, 63, 23, 1, 0, 0, 4764, 0, 0, 2335, 0, 25, 27, 0, 0, 2302, 5, 0, 1676, 1, 59, 389]

以上這篇python下對hsv顏色空間進行量化操作就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 毛片免费观看的视频在线 | 美日韩一区二区三区 | 毛片免费全部免费播放 | 亚洲精品一区二区三区网址 | 国产三级三级三级 | 亚洲国产精品久久精品成人 | 国产成人丝袜网站在线观看 | 在线观看精品视频网站www | 京东一热本色道久久爱 | 亚洲欧美成人综合久久久 | 日本精品一区二区三区在线 | 亚洲成a v人片在线看片 | 欧美激情久久久久久久久 | 国产免费影院 | 色伦网| 国产精品欧美激情在线播放 | 久久综合九九 | 国内精品久久久久久久亚洲 | 国产成人夜间影院在线观看 | 欧美午夜精品久久久久免费视 | 国产美女一区二区三区 | 中国美女乱淫免费看视频 | 一级国产a级a毛片无卡 | 九九九免费视频 | 97精品国产91久久久久久 | 亚洲 欧美 中文字幕 | 成年女人免费又黄又爽视频 | 中文字幕有码在线播放 | 日本在线观看网址 | 欧美日韩国产免费一区二区三区 | 免费的成人a视频在线观看 免费的毛片 | 99久久在线| 免费看欧美一级a毛片 | 怡红院在线观看视频 | 美女黄色在线网站大全 | 亚洲一区二区三区高清网 | 欧美一级久久久久久久久大 | 亚洲精品一区二区三区四区 | 操碰91| 日韩在线观看中文字幕 | 日本高清视频www夜色资源 |