0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

一個關(guān)于尋找圖像中最亮點的教程的后續(xù)

新機(jī)器視覺 ? 來源:AI算法與圖像處理 ? 作者:AI算法與圖像處理 ? 2021-06-18 11:41 ? 次閱讀

今天的博客文章是我?guī)啄昵白龅囊粋€關(guān)于尋找圖像中最亮點的教程的后續(xù)。

我之前的教程假設(shè)在圖像中只有一個亮點你想要檢測。。.

但如果有多個亮點呢?

如果您想在圖像中檢測多個亮點,代碼會稍微復(fù)雜一點,但不會太復(fù)雜。不過不用擔(dān)心:我將詳細(xì)解釋每一個步驟。

看看下面的圖片:

2fa98c60-cf69-11eb-9e57-12bb97331649.jpg

在這幅圖中,我們有五個燈泡。

我們的目標(biāo)是檢測圖像中的這五個燈泡,并對它們進(jìn)行唯一的標(biāo)記。

首先,打開一個新文件并將其命名為detect_bright_spot .py。然后,插入以下代碼:

# import the necessary packagesfrom imutils import contoursfrom skimage import measureimport numpy as npimport argparseimport imutilsimport cv2# construct the argument parse and parse the argumentsap = argparse.ArgumentParser()ap.add_argument(“-i”, “--image”, required=True, help=“path to the image file”)args = vars(ap.parse_args())

導(dǎo)入一些必要的包和命令行參數(shù)。

要開始檢測圖像中最亮的區(qū)域,我們首先需要從磁盤加載我們的圖像,然后將其轉(zhuǎn)換為灰度圖并進(jìn)行平滑濾波,以減少高頻噪聲:

# load the image, convert it to grayscale, and blur itimage = cv2.imread(args[“image”])gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)blurred = cv2.GaussianBlur(gray, (11, 11), 0)

這些操作的輸出如下:

2fcf2f1a-cf69-11eb-9e57-12bb97331649.png

為了顯示模糊圖像中最亮的區(qū)域,我們需要應(yīng)用閾值化:

# threshold the image to reveal light regions in the# blurred imagethresh = cv2.threshold(blurred, 200, 255, cv2.THRESH_BINARY)[1]

操作取任意像素值p 》= 200,并將其設(shè)置為255(白色)。像素值《 200被設(shè)置為0(黑色)。

閾值化后,我們得到如下圖像:

2fe920c8-cf69-11eb-9e57-12bb97331649.png

注意圖像的明亮區(qū)域現(xiàn)在都是白色的,而其余的圖像被設(shè)置為黑色。

然而,在這幅圖像中有一點噪聲(即,小斑點),所以讓我們通過執(zhí)行一系列的腐蝕和膨脹操作來清除它:

# perform a series of erosions and dilations to remove# any small blobs of noise from the thresholded imagethresh = cv2.erode(thresh, None, iterations=2)thresh = cv2.dilate(thresh, None, iterations=4)

在應(yīng)用這些操作之后,你可以看到我們的thresh圖像變得更加“干凈”,但是仍然有一些我們想要移除的斑點。

303a4fde-cf69-11eb-9e57-12bb97331649.png

本項目的關(guān)鍵步驟是對上圖中的每個區(qū)域進(jìn)行標(biāo)記,然而,即使在應(yīng)用了腐蝕和膨脹后,我們?nèi)匀幌胍^濾掉剩余的小塊兒區(qū)域。

一個很好的方法是執(zhí)行連接組件分析:

# perform a connected component analysis on the thresholded# image, then initialize a mask to store only the “l(fā)arge”# componentslabels = measure.label(thresh, neighbors=8, background=0)mask = np.zeros(thresh.shape, dtype=“uint8”)# loop over the unique componentsfor label in np.unique(labels): # if this is the background label, ignore it if label == 0: continue # otherwise, construct the label mask and count the # number of pixels labelMask = np.zeros(thresh.shape, dtype=“uint8”) labelMask[labels == label] = 255 numPixels = cv2.countNonZero(labelMask) # if the number of pixels in the component is sufficiently # large, then add it to our mask of “l(fā)arge blobs” if numPixels 》 300: mask = cv2.add(mask, labelMask)

第4行使用scikit-image庫執(zhí)行實際的連接組件分析。measure.lable返回的label和我們的閾值圖像有相同的大小,唯一的區(qū)別就是label存儲的為閾值圖像每一斑點對應(yīng)的正整數(shù)。

然后我們在第5行初始化一個掩膜來存儲大的斑點。

第7行我們開始循環(huán)遍歷每個label中的正整數(shù)標(biāo)簽,如果標(biāo)簽為零,則表示我們正在檢測背景并可以安全的忽略它(9,10行)。

否則,我們?yōu)楫?dāng)前區(qū)域構(gòu)建一個掩碼。

下面我提供了一個GIF動畫,它可視化地構(gòu)建了每個標(biāo)簽的labelMask。使用這個動畫來幫助你了解如何訪問和顯示每個單獨的組件:

305158fa-cf69-11eb-9e57-12bb97331649.gif

然后第15行對labelMask中的非零像素進(jìn)行計數(shù)。如果numPixels超過了一個預(yù)先定義的閾值(在本例中,總數(shù)為300像素),那么我們認(rèn)為這個斑點“足夠大”,并將其添加到掩膜中。

輸出掩模如下圖:

注意,所有小的斑點都被過濾掉了,只有大的斑點被保留了下來。

最后一步是在我們的圖像上繪制標(biāo)記的斑點:

# find the contours in the mask, then sort them from left to# rightcnts = cv2.findContours(mask.copy(), cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)cnts = imutils.grab_contours(cnts)cnts = contours.sort_contours(cnts)[0]# loop over the contoursfor (i, c) in enumerate(cnts): # draw the bright spot on the image (x, y, w, h) = cv2.boundingRect(c) ((cX, cY), radius) = cv2.minEnclosingCircle(c) cv2.circle(image, (int(cX), int(cY)), int(radius), (0, 0, 255), 3) cv2.putText(image, “#{}”.format(i + 1), (x, y - 15), cv2.FONT_HERSHEY_SIMPLEX, 0.45, (0, 0, 255), 2)# show the output imagecv2.imshow(“Image”, image)cv2.waitKey(0)

首先,我們需要檢測掩模圖像中的輪廓,然后按從左到右排序(3-7行)。

一旦我們的輪廓已經(jīng)排序,我們可以對它們進(jìn)行單獨的循環(huán)處理(第8行)。

對于這些輪廓線,我們將計算出代表明亮區(qū)域的最小包圍圓(第12行)。

然后,我們唯一地標(biāo)記該區(qū)域并在圖像上繪制它(第12-15行)。

最后,第17行和第18行顯示了輸出結(jié)果。

運行程序,你應(yīng)該會看到以下輸出圖像:

請注意,每個燈泡都被獨特地標(biāo)上了圓圈,圓圈圍繞著每個單獨的明亮區(qū)域。

責(zé)任編輯:lq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • OpenCV
    +關(guān)注

    關(guān)注

    29

    文章

    622

    瀏覽量

    41091
  • 檢測圖像
    +關(guān)注

    關(guān)注

    0

    文章

    3

    瀏覽量

    5525
  • python
    +關(guān)注

    關(guān)注

    53

    文章

    4753

    瀏覽量

    84082

原文標(biāo)題:使用Python和OpenCV檢測圖像中的多個亮點

文章出處:【微信號:vision263com,微信公眾號:新機(jī)器視覺】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    圖像識別算法的核心技術(shù)是什么

    圖像識別算法是計算機(jī)視覺領(lǐng)域的重要研究方向,其目標(biāo)是使計算機(jī)能夠像人類樣理解和識別圖像中的內(nèi)容。
    的頭像 發(fā)表于 07-16 11:02 ?370次閱讀

    圖像識別技術(shù)的原理是什么

    圖像識別技術(shù)是種利用計算機(jī)視覺和機(jī)器學(xué)習(xí)技術(shù)對圖像進(jìn)行分析和理解的技術(shù)。它可以幫助計算機(jī)識別和理解圖像中的對象、場景和活動。 圖像預(yù)處理
    的頭像 發(fā)表于 07-16 10:46 ?594次閱讀

    機(jī)器人視覺技術(shù)中圖像分割方法有哪些

    機(jī)器人視覺技術(shù)是人工智能領(lǐng)域的重要分支,它涉及到圖像處理、模式識別、機(jī)器學(xué)習(xí)等多個學(xué)科。圖像分割是機(jī)器人視覺技術(shù)中的
    的頭像 發(fā)表于 07-04 11:34 ?390次閱讀

    FPGA設(shè)計經(jīng)驗之圖像處理

    的濾波、取邊緣、膨脹腐蝕等算法。可能大家會覺得這些運算似乎都是最基本的圖像處理運算,只是前端的預(yù)處理,似乎用處不大。但問題是只有FPGA做這樣的運算才是速度最快效率最高的,比如用CPU做一個取邊緣
    發(fā)表于 06-12 16:26

    STM32H723 SD卡旦掛載失敗,后續(xù)無法繼續(xù)掛載,怎么解決?

    命令出現(xiàn)失?。ㄕ#迳蟂D卡后繼續(xù)使用掛載命令還是掛載失?。ú徽#?問題分析: 旦掛載失敗,后續(xù)無法繼續(xù)掛載,可能和掛載失敗的第次有關(guān),尋找
    發(fā)表于 05-30 07:38

    尋找能夠PID調(diào)節(jié)的仿真軟件

    最近想學(xué)習(xí)些有關(guān)PID調(diào)節(jié)的知識,有沒有些相關(guān)資料推薦?文章書籍什么隨便都可以;還有就是尋找幾款有關(guān)PID在線調(diào)節(jié)的網(wǎng)址或者軟件,能夠使我對PID的調(diào)節(jié)過程有
    發(fā)表于 02-29 22:44

    鴻蒙開發(fā)圖形圖像——@ohos.effectKit (圖像效果)

    圖像效果提供處理圖像些基礎(chǔ)能力,包括對當(dāng)前圖像的亮度調(diào)節(jié)、模糊化、灰度調(diào)節(jié)、智能取色等。 該模塊提供以下圖像效果相關(guān)的常用功能: Fil
    的頭像 發(fā)表于 02-22 16:08 ?284次閱讀
    鴻蒙開發(fā)圖形<b class='flag-5'>圖像</b>——@ohos.effectKit (<b class='flag-5'>圖像</b>效果)

    圖像跟蹤設(shè)備發(fā)展歷史

    傳統(tǒng)意義上的圖像跟蹤主要分為兩種,種是通過在定載體上安裝定位設(shè)備并結(jié)合無線傳輸設(shè)備對載體的實時位置進(jìn)行定位或描繪出移動軌跡,這種跟蹤設(shè)備主要用于消防、戶外探險等領(lǐng)域。另種跟蹤設(shè)備
    的頭像 發(fā)表于 02-20 08:28 ?347次閱讀
    <b class='flag-5'>圖像</b>跟蹤設(shè)備發(fā)展歷史

    關(guān)于數(shù)字圖像處理的常用技巧

    圖像生成采集處理過程中都會不同程度的引入各種噪聲,因此會導(dǎo)致圖像的質(zhì)量變差。從而影響對圖像的識別。所以必須要對圖像進(jìn)行濾波,所以必須對圖像進(jìn)
    的頭像 發(fā)表于 02-19 09:27 ?685次閱讀
    <b class='flag-5'>關(guān)于</b>數(shù)字<b class='flag-5'>圖像</b>處理的常用技巧

    計算機(jī)視覺、計算機(jī)圖像學(xué)和圖像處理詳解

    門讓計算機(jī)從圖像中提取有用信息并加以分析的科學(xué)。這些信息后續(xù)可以用于輔助些決策或者任務(wù),比如醫(yī)學(xué)圖像分析、工程測量、自動駕駛、機(jī)器人學(xué)等
    的頭像 發(fā)表于 12-21 16:15 ?853次閱讀
    計算機(jī)視覺、計算機(jī)<b class='flag-5'>圖像</b>學(xué)和<b class='flag-5'>圖像</b>處理詳解

    FPGA圖像處理方法

    圖像在采集和傳輸?shù)倪^程中,通常會產(chǎn)生噪聲,使圖像質(zhì)量降低,影響后續(xù)處理。因此須對圖像進(jìn)行圖像
    的頭像 發(fā)表于 12-02 13:15 ?913次閱讀

    關(guān)于圖像傳感器圖像質(zhì)量的四大誤區(qū)!你踩過幾個坑?

    關(guān)于圖像傳感器圖像質(zhì)量的四大誤區(qū)!你踩過幾個坑?
    的頭像 發(fā)表于 11-27 16:56 ?348次閱讀
    <b class='flag-5'>關(guān)于</b><b class='flag-5'>圖像</b>傳感器<b class='flag-5'>圖像</b>質(zhì)量的四大誤區(qū)!你踩過幾個坑?

    GaN-Based如何在EMI和功耗之間尋找最優(yōu)的平衡?

    GaN-Based如何在EMI和功耗之間尋找最優(yōu)的平衡? GaN-Based材料是種具有廣泛應(yīng)用前景的寬能隙半導(dǎo)體材料,其在高頻功率電子設(shè)備中具有許多優(yōu)勢,如高功率密度、高工作溫
    的頭像 發(fā)表于 11-07 10:35 ?395次閱讀

    關(guān)于恒流源來測模擬量的方式

    昨天我們聊了用電橋的方式來進(jìn)行測試,在里面說了關(guān)于恒流源來測模擬量的方式,在我們些模擬量變化測量中要求采用恒流源的方式來進(jìn)行測量
    的頭像 發(fā)表于 10-18 14:28 ?577次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>個</b><b class='flag-5'>關(guān)于</b>恒流源來測模擬量的方式

    關(guān)于串口的小問題

    前段時間寫了幾行代碼,其中有部分是關(guān)于串口接收的,仿真調(diào)試是沒有問題的,但是下載之后就出問題了,不過問題并沒有出現(xiàn)在代碼上,而是在上位機(jī)發(fā)送的數(shù)據(jù)上,這兩天突然找到了問題所在,然后就發(fā)現(xiàn)這個問題并不能稱作是
    的頭像 發(fā)表于 09-25 14:21 ?352次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>個</b><b class='flag-5'>關(guān)于</b>串口的小問題