OpenCV-Python 直方圖-4:直方圖反投影|二十九

2020-12-03 人工智慧遇見磐創

目標

在本章中,我們將學習直方圖反投影。

理論

這是由Michael J. SwainDana H. Ballard在他們的論文《通過顏色直方圖索引》中提出的。

用簡單的話說是什麼意思?它用於圖像分割或在圖像中查找感興趣的對象。簡而言之,它創建的圖像大小與輸入圖像相同(但只有一個通道),其中每個像素對應於該像素屬於我們物體的概率。用更簡單的話來說,與其餘部分相比,輸出圖像將在可能有對象的區域具有更多的白色值。好吧,這是一個直觀的解釋。(我無法使其更簡單)。直方圖反投影與camshift算法等配合使用。

我們該怎麼做呢?我們創建一個圖像的直方圖,其中包含我們感興趣的對象(在我們的示例中是背景,離開播放器等)。對象應儘可能填充圖像以獲得更好的效果。而且顏色直方圖比灰度直方圖更可取,因為對象的顏色對比灰度強度是定義對象的好方法。然後,我們將該直方圖「反投影」到需要找到對象的測試圖像上,換句話說,我們計算出屬於背景的每個像素的概率並將其顯示出來。在適當的閾值下產生的輸出使我們僅獲得背景。

Numpy中的算法

1.首先,我們需要計算我們要查找的對象(使其為「 M」)和要搜索的圖像(使其為「 I」)的顏色直方圖。

import numpy as npimport cv2 as cvfrom matplotlib import pyplot as plt#roi是我們需要找到的對象或對象區域roi = cv.imread('rose_red.png')hsv = cv.cvtColor(roi,cv.COLOR_BGR2HSV)#目標是我們搜索的圖像target = cv.imread('rose.png')hsvt = cv.cvtColor(target,cv.COLOR_BGR2HSV)# 使用calcHist查找直方圖。也可以使用np.histogram2d完成M = cv.calcHist([hsv],[0, 1], None, [180, 256], [0, 180, 0, 256] )I = cv.calcHist([hsvt],[0, 1], None, [180, 256], [0, 180, 0, 256] )2.求出比值R=M/I。然後反向投影R,即使用R作為調色板,並以每個像素作為其對應的目標概率創建一個新圖像。即B(x,y) = R[h(x,y),s(x,y)] 其中h是色調,s是像素在(x,y)的飽和度。之後,應用條件B(x,y) = min[B(x,y), 1]。

h,s,v = cv.split(hsvt)B = R[h.ravel(),s.ravel()]B = np.minimum(B,1)B = B.reshape(hsvt.shape[:2])3.現在對圓盤應用卷積,B = D * B,其中D是圓盤內核。

disc = cv.getStructuringElement(cv.MORPH_ELLIPSE,(5,5))cv.filter2D(B,-1,disc,B)B = np.uint8(B)cv.normalize(B,B,0,255,cv.NORM_MINMAX)4.現在最大強度的位置給了我們物體的位置。如果我們期望圖像中有一個區域,則對合適的值進行閾值處理將獲得不錯的結果。

ret,thresh = cv.threshold(B,50,255,0) 就是這樣!!

OpenCV的反投影

OpenCV提供了一個內建的函數cv.calcBackProject()。它的參數幾乎與cv.calchist()函數相同。它的一個參數是直方圖,也就是物體的直方圖,我們必須找到它。另外,在傳遞給backproject函數之前,應該對對象直方圖進行歸一化。它返回概率圖像。然後我們用圓盤內核對圖像進行卷積並應用閾值。下面是我的代碼和結果:

import numpy as npimport cv2 as cvroi = cv.imread('rose_red.png')hsv = cv.cvtColor(roi,cv.COLOR_BGR2HSV)target = cv.imread('rose.png')hsvt = cv.cvtColor(target,cv.COLOR_BGR2HSV)# 計算對象的直方圖roihist = cv.calcHist([hsv],[0, 1], None, [180, 256], [0, 180, 0, 256] )# 直方圖歸一化並利用反傳算法cv.normalize(roihist,roihist,0,255,cv.NORM_MINMAX)dst = cv.calcBackProject([hsvt],[0,1],roihist,[0,180,0,256],1)# 用圓盤進行卷積disc = cv.getStructuringElement(cv.MORPH_ELLIPSE,(5,5))cv.filter2D(dst,-1,disc,dst)# 應用閾值作與操作ret,thresh = cv.threshold(dst,50,255,0)thresh = cv.merge((thresh,thresh,thresh))res = cv.bitwise_and(target,thresh)res = np.vstack((target,thresh,res))cv.imwrite('res.jpg',res)以下是我處理過的一個示例。我將藍色矩形內的區域用作示例對象,我想提取整個地面。

附加資源

"Indexing via color histograms", Swain, Michael J. , Third international conference on computer vision,1990.

相關焦點

  • 「python opencv視覺零基礎」十四、直方圖反向投影
    前文提醒:博主正在參加博客之星評比,成功入選Top200,現在暫居第九歡迎各位點擊了解更多幫我投票,非常感謝~目錄「python opencv 計算機視覺零基礎實戰」 第一節「python opencv視覺入門到實戰」二、格式與攝像頭「python opencv 視覺入門到實戰」 三、圖像編輯「python
  • OpenCV-Python 直方圖-3:二維直方圖|二十八
    目標在本章中,我們將學習查找和繪製2D直方圖。這將在以後的章節中有所幫助。介紹在第一篇文章中,我們計算並繪製了一維直方圖。 之所以稱為一維,是因為我們僅考慮一個特徵,即像素的灰度強度值。 但是在二維直方圖中,您要考慮兩個特徵。
  • OpenCV-Python 直方圖-2:直方圖均衡|二十七
    例如,在人臉識別中,在對人臉數據進行訓練之前,對人臉圖像進行直方圖均衡化處理,使其具有相同的光照條件。OpenCV中的直方圖均衡OpenCV具有執行此操作的功能cv.equalizeHist()。它的輸入只是灰度圖像,輸出是我們的直方圖均衡圖像。
  • 深入理解OpenCV+Python直方圖均衡化
    直方圖均衡化是圖像處理領域中利用圖像直方圖對對比度進行調整的方法。
  • OpenCV-Python 直方圖-1:查找、繪製和分析|二十六
    當今幾乎所有圖像處理工具都提供直方圖功能。以下是劍橋彩色網站的圖片,我建議您訪問該網站以獲取更多詳細信息。您可以看到圖像及其直方圖。(請記住,此直方圖是針對灰度圖像而非彩色圖像繪製的)。直方圖的左側區域顯示圖像中較暗像素的數量,而右側區域則顯示明亮像素的數量。從直方圖中,您可以看到暗區域多於亮區域,而中間調的數量(中間值的像素值,例如127附近)則非常少。
  • 基於OpenCv 和 Python 的手指識別及追蹤
    翻譯 | 餘杭 Lamaric 校對 | 吳曉曼 審核 | 餘杭詳細代碼參考:https://github.com/amarlearning/opencv手指追蹤是許多計算機視覺應用的重要特徵。在該應用中,使用基於直方圖的方法將手與背景幀分離。
  • Python學習第89課-數據可視化之直方圖繪製
    【每天幾分鐘,從零入門python編程的世界!】假設你想投資某一個城市的房地產,你肯定需要對這個城市的人口分布、增長潛力做一個調查,這時我們就需要做一個直方圖(histogram plot)。實例:假設我們有一份C城市的人口年齡的數據,我們為方便起見,在這裡只列出很少的一部分數據,用一個列表City_C_Age表示這個城市的人口年齡數據:City_C_Age=[2,3,1,7,4,5,3,1,7,6,9,8,13,16,12,17,15,14,18,,20,23,28,25,23,27,25,29,26,24,25,30,34,37,36,38,32,35,37,36,41,42,47,47,48,43,46,44,53,54,58,52,51,55,56,69,60,63,67,64,72,74,78,75,89,85,83,90,93
  • 圖像算法工程師必備:灰度直方圖
    圖像的灰度直方圖,大概是數字圖像處理專業課接觸到的第一節講圖像具體算法的一堂課了。所謂的灰度直方圖,就是統計一個8比特的灰度圖像,其灰度等級從0到255的像素的分布情況。我們很容易就能想到,一幅圖像對應唯一的直方圖,而同一直方圖肯定會對應很多不同的圖像。
  • opencv教程-目標跟蹤
    1:MeanShift算法retval, window=cv.meanShift(probImage, window, criteria)參數probImage:當前圖像反向投影圖參數window:前一圖像目標框參數criteria:迭代停止條件
  • 頻數直方圖簡稱為直方圖的各種圖形
    頻數直方圖簡稱為直方圖,是用來顯示某一種質量特性數據的分布狀況的。直方圖由一系列寬度相等高度不同的相鄰長方形組成,橫坐標表示產品質量特性值,長方形的寬度就是數據分組的組距間隔,縱坐標表示每組內數據的頻數,也就是每組內產品的數目。
  • 直方圖是什麼,及直方圖在攝影中的應用
    作為一張圖片的「資料庫」,直方圖裡基本包含了圖片的所有數據,我們可以通過直方圖來了解照片的真實信息。學會直方圖,不論是在前期拍攝,還是在照片的後期修飾,都能起到事半功倍的效果。今天,我們就從以下幾個部分來深入了解直方圖。
  • 你絕對看得懂直方圖!照片直方圖的講解與攝影應用
    無論是攝影前期還是後期我們都經常會用到直方圖,剛接觸攝影的人可能有點不好理解,不過不要緊,讀完此文你可以充分理解並在拍攝過程種使用它,並用它來提高你的拍照水平。它實際上很容易使用。直方圖是照片色調範圍的圖形表示,可幫助你評估曝光。
  • python可視化:matplotlib繪製直方圖進階篇!
    在上篇文章中介紹了直方圖的前五個參數,實際上直方圖一共有十幾個參數,剩下的參數利用這篇文章解釋清楚,讓大家能夠將如何繪製直方圖理解的透透的。bottom參數這個參數的含義也很直觀,底部的意思,指的是條形的底從哪裡開始。
  • 一萱攝影 淺談攝影裡的直方圖 什麼是直方圖
    在我們才買相機,好不容易拍攝出幾張自認為不錯的片子,就發到那些攝影網站攝影論壇上面,請一些有經驗的攝影人來點評一下,他們有時就會問你要拍攝時的直方圖,往往會弄得作為攝影新手的你雲裡霧裡,感覺直方圖這個東西很高大上一樣,根本不知道怎麼回答,今天就來和大家說說什麼是直方圖。
  • 超級詳細的直方圖應用步驟及分析,一篇搞定直方圖!
    (直方圖適用於連續性數據) 我們要如何解讀直方圖?兩臺不同的機器或兩種不同原料間存在差異時,或者作業者不同時也可發生此類直方圖。例如,病歷質控的2位質控員對檢查標準掌握有差異時,又或者同一位質控員應用兩種評估標準檢測的結果。出現這類情況時,應將數據層別處理後再製作直方圖。4. 鋸齒型:圖形的柱形高低不一,呈現缺齒的形狀。
  • 什麼是直方圖,攝影中直方圖怎麼看?
    圖片中的直方圖顯示了每種顏色(紅色,藍色和綠色)的像素值分布,它們與次要顏色(洋紅色,青色和黃色)重疊,最後顯示了包含所有三種顏色並顯示為灰色的區域。直方圖分析當圖像曝光良好時,直方圖將在中間包含大條形圖,而在邊緣周圍則幾乎沒有信息。
  • Photoshop直方圖
    2、初打開的照片及直方圖雖然是對應的關係,但此時的直方圖並不十分準確,需要單擊直方圖右上角帶嘆號(!)的三角標誌才可以,這個標誌稱為高速緩存。高速緩存:顯示高速緩存圖標時,表示當前顯示的直方圖並不是照片的真實直方圖,單擊關閉高速緩存,才會顯示最準確的直方圖。
  • MedCalc16: 4.3.1分布圖: 直方圖
    4.3 分布圖MedCalc的分布圖包括直方圖(histogram)、累積頻率分布圖(cumulative frequency distribution
  • 圖像增強、銳化,利用 Python-OpenCV 來實現 4 種方法!
    目前較為常用的幾個方法:伽馬變換、線性變換、分段線性變換、直方圖均衡化,對於圖像對比度增強,都能取得不錯的效果!本文將對每種方法 簡單介紹一下,並藉助於 Python 、OpenCV 進行代碼實現,提前說一下哈,下面處理的圖像對象都是單通道灰度圖,不是三通道彩色圖!
  • 教大家解讀直方圖的作用,學會看懂直方圖是攝影的基礎
    這節課教大家如何看懂直方圖,直方圖顯示是什麼?大家看一下,左上角是拍攝一張純白色的畫面,在來看直方圖,直方圖右側有一個峰值起來了,其他部分是空的,如果拍攝一張純黑色的畫面(左下角)大家看直方圖的峰值在最左側,其他地方也都沒有峰值,在看右上純灰色畫面,峰值又出現在正中的位置,左右是空的,右下角從純黑到純白漸變的這麼一個畫面,整個直方圖顯得非常飽滿,這說明了越是偏向直方圖的右側,它記錄的是畫面亮的信息