99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

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

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

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

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

新機(jī)器視覺(jué) ? 來(lái)源:AI算法與圖像處理 ? 作者:AI算法與圖像處理 ? 2021-06-18 11:41 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

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

但如果有多個(gè)亮點(diǎn)呢?

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

看看下面的圖片:

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

在這幅圖中,我們有五個(gè)燈泡。

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

首先,打開(kāi)一個(gè)新文件并將其命名為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ù)。

要開(kāi)始檢測(cè)圖像中最亮的區(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è)置為黑色。

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

# 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圖像變得更加“干凈”,但是仍然有一些我們想要移除的斑點(diǎn)。

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

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

一個(gè)很好的方法是執(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庫(kù)執(zhí)行實(shí)際的連接組件分析。measure.lable返回的label和我們的閾值圖像有相同的大小,唯一的區(qū)別就是label存儲(chǔ)的為閾值圖像每一斑點(diǎn)對(duì)應(yīng)的正整數(shù)。

然后我們?cè)诘?行初始化一個(gè)掩膜來(lái)存儲(chǔ)大的斑點(diǎn)。

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

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

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

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

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

輸出掩模如下圖:

注意,所有小的斑點(diǎn)都被過(guò)濾掉了,只有大的斑點(diǎn)被保留了下來(lái)。

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

# 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)

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

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

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

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

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

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

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

責(zé)任編輯:lq

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

    關(guān)注

    32

    文章

    642

    瀏覽量

    42936
  • 檢測(cè)圖像
    +關(guān)注

    關(guān)注

    0

    文章

    3

    瀏覽量

    5582
  • python
    +關(guān)注

    關(guān)注

    56

    文章

    4827

    瀏覽量

    86830

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

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

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    基于LockAI視覺(jué)識(shí)別模塊:C++模板匹配

    模板匹配是種在圖像尋找特定模式的技術(shù)。它通過(guò)滑動(dòng)個(gè)模板圖像(較小的
    的頭像 發(fā)表于 05-13 14:14 ?211次閱讀
    基于LockAI視覺(jué)識(shí)別模塊:C++模板匹配

    純小白,尋找直會(huì)發(fā)射信號(hào)的藍(lán)牙

    藍(lán)牙。 我目前用的是紅米手表在車上,當(dāng)手機(jī)自動(dòng)連接手表藍(lán)牙后解鎖,斷開(kāi)藍(lán)牙鎖車。 遇到的問(wèn)題就是藍(lán)牙手表信號(hào)太好,很遠(yuǎn)就解鎖,下車走很遠(yuǎn)也才會(huì)鎖車。 想尋找個(gè)可以調(diào)節(jié)發(fā)射信號(hào)(方便我手機(jī)10米左右再
    發(fā)表于 03-27 21:58

    Linux系統(tǒng)中最重要的三個(gè)命令

    Linux三劍客是Linux系統(tǒng)中最重要的三個(gè)命令,它們以其強(qiáng)大的功能和廣泛的應(yīng)用場(chǎng)景而聞名。這三個(gè)工具的組合使用幾乎可以完美應(yīng)對(duì)Shell中的數(shù)據(jù)分析場(chǎng)景,因此被統(tǒng)稱為L(zhǎng)inux三劍客。
    的頭像 發(fā)表于 03-03 10:37 ?442次閱讀

    圖像采集卡:現(xiàn)代圖像處理技術(shù)的關(guān)鍵組件

    在現(xiàn)代科技快速發(fā)展的背景下,圖像處理技術(shù)已成為信息技術(shù)領(lǐng)域不可或缺的部分。圖像采集卡,作為連接計(jì)算機(jī)與各種圖像采集設(shè)備的重要硬件組件,扮演著至關(guān)重要的角色。它不僅涉及
    的頭像 發(fā)表于 02-20 10:42 ?499次閱讀
    <b class='flag-5'>圖像</b>采集卡:現(xiàn)代<b class='flag-5'>圖像</b>處理技術(shù)的關(guān)鍵組件

    將攝像頭和顯示屏包裝成個(gè)類,然后在其他文件中只會(huì)使用次,為什么會(huì)卡在個(gè)地方獲取不了圖像

    將攝像頭和顯示屏包裝成個(gè)類,然后在其他文件中只會(huì)使用次,為什么會(huì)卡在個(gè)地方,然后就獲取不了
    發(fā)表于 02-08 07:04

    FPGA圖像處理基礎(chǔ)----實(shí)現(xiàn)緩存卷積窗口

    像素行與像素窗口 圖像是由一個(gè)個(gè)像素點(diǎn)構(gòu)成的,對(duì)于幅480*272大小的圖片來(lái)說(shuō),其寬度是480,高度是272。在使用FPGA進(jìn)行圖像
    的頭像 發(fā)表于 02-07 10:43 ?844次閱讀
    FPGA<b class='flag-5'>圖像</b>處理基礎(chǔ)----實(shí)現(xiàn)緩存卷積窗口

    關(guān)于cypress 3014輸出rgb24圖像

    使用的是cypress 3014,輸出yuy2的時(shí)候圖像都正常的,但我修改為rgb24輸出,圖像是顛倒的,關(guān)于我的demo板,7611只是調(diào)試了顏色寄存器,fpga保證是rgb24,3014也是只
    發(fā)表于 01-23 15:08

    基于XIAO nRF52840的鑰匙尋找

    今天小編帶來(lái)是創(chuàng)客Hamid Sheibani的項(xiàng)目:鑰匙尋找器。使用了XIAO nRF52840開(kāi)發(fā)板,與鑰匙串結(jié)合,讓你告別日常尋找鑰匙的煩惱! 背景故事 ? 該設(shè)備利用低功耗藍(lán)牙(BLE)技術(shù)
    的頭像 發(fā)表于 01-17 11:03 ?584次閱讀
    基于XIAO nRF52840的鑰匙<b class='flag-5'>尋找</b>器

    關(guān)于閃測(cè)儀常見(jiàn)的問(wèn)題及回答

    測(cè)物體表面時(shí),相機(jī)捕捉物體的輪廓和細(xì)節(jié)特征,然后利用圖像分析軟件,根據(jù)拍攝到的圖像信息,通過(guò)算法來(lái)精確測(cè)量物體的尺寸、形狀、位置等幾何參數(shù)。例如,在測(cè)量個(gè)小型精
    的頭像 發(fā)表于 12-30 14:19 ?745次閱讀
    <b class='flag-5'>關(guān)于</b>閃測(cè)儀常見(jiàn)的問(wèn)題及回答

    AD7616輸出異常,導(dǎo)致后續(xù)控制的IGBT炸掉怎么解決?

    AD7616在正常工作30個(gè)小時(shí)后出現(xiàn)輸出保持狀態(tài),后經(jīng)過(guò)段時(shí)間,驅(qū)動(dòng)和FPGA有交互,但輸出異常,導(dǎo)致后續(xù)控制的IGBT炸掉。目前AD7616是在硬件并口且未使用復(fù)位功能。初步判斷是外部干擾造成的AD7616輸出異常,想咨詢
    發(fā)表于 12-19 06:32

    一個(gè)月速成python+OpenCV圖像處理

    適用于哪些場(chǎng)景,然后通過(guò)Python編寫代碼來(lái)實(shí)現(xiàn)這些算法,并應(yīng)用于實(shí)際項(xiàng)目中,實(shí)現(xiàn)圖像的檢測(cè)、識(shí)別、分類、定位、測(cè)量等目標(biāo)。本文將介紹個(gè)高效學(xué)習(xí)Python+O
    的頭像 發(fā)表于 11-29 18:27 ?467次閱讀
    <b class='flag-5'>一個(gè)</b>月速成python+OpenCV<b class='flag-5'>圖像</b>處理

    關(guān)于濾波器的個(gè)問(wèn)題

    想問(wèn)一下關(guān)于濾波器的個(gè)問(wèn)題 http://www.gz.wiki/http://www.gz.wiki/
    發(fā)表于 11-12 21:43

    使用Python進(jìn)行圖像處理

    下面是個(gè)關(guān)于使用Python在幾行代碼中分析城市輪廓線的快速教程。
    的頭像 發(fā)表于 11-07 10:14 ?592次閱讀
    使用Python進(jìn)行<b class='flag-5'>圖像</b>處理

    共聚焦激光顯微鏡圖像處理技巧

    共聚焦激光顯微鏡圖像處理技巧涉及多個(gè)方面,以下是些關(guān)鍵的步驟和注意事項(xiàng): 、圖像預(yù)處理 文件格式選擇 : 在拍攝好圖像后,保存的圖象格式
    的頭像 發(fā)表于 10-30 09:37 ?2650次閱讀

    DSP教學(xué)實(shí)驗(yàn)箱_數(shù)字圖像處理操作_案例分享:5-13 灰度圖像二值化

    、實(shí)驗(yàn)?zāi)康?學(xué)習(xí)灰度圖像二值化的原理,掌握圖像的讀取方法,并實(shí)現(xiàn)在LCD上顯示二值化前后的圖像。 二、實(shí)驗(yàn)原理 圖像二值化
    發(fā)表于 07-25 15:03