在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

一個關于尋找圖像中最亮點的教程的后續

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

掃碼添加小助手

加入工程師交流群

今天的博客文章是我幾年前做的一個關于尋找圖像中最亮點的教程的后續。

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

但如果有多個亮點呢?

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

看看下面的圖片:

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

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

我們的目標是檢測圖像中的這五個燈泡,并對它們進行唯一的標記。

首先,打開一個新文件并將其命名為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())

導入一些必要的包和命令行參數。

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

# 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

為了顯示模糊圖像中最亮的區域,我們需要應用閾值化:

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

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

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

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

注意圖像的明亮區域現在都是白色的,而其余的圖像被設置為黑色。

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

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

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

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

本項目的關鍵步驟是對上圖中的每個區域進行標記,然而,即使在應用了腐蝕和膨脹后,我們仍然想要過濾掉剩余的小塊兒區域。

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

# perform a connected component analysis on the thresholded# image, then initialize a mask to store only the “large”# 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 “large blobs” if numPixels 》 300: mask = cv2.add(mask, labelMask)

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

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

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

否則,我們為當前區域構建一個掩碼。

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

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

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

輸出掩模如下圖:

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

最后一步是在我們的圖像上繪制標記的斑點:

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

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

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

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

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

運行程序,你應該會看到以下輸出圖像:

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

責任編輯:lq

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • OpenCV
    +關注

    關注

    32

    文章

    642

    瀏覽量

    42770
  • 檢測圖像
    +關注

    關注

    0

    文章

    3

    瀏覽量

    5577
  • python
    +關注

    關注

    56

    文章

    4826

    瀏覽量

    86602

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

文章出處:【微信號:vision263com,微信公眾號:新機器視覺】歡迎添加關注!文章轉載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    基于LockAI視覺識別模塊:C++模板匹配

    模板匹配是種在圖像尋找特定模式的技術。它通過滑動模板圖像(較小的
    的頭像 發表于 05-13 14:14 ?178次閱讀
    基于LockAI視覺識別模塊:C++模板匹配

    Linux系統中最重要的三命令

    Linux三劍客是Linux系統中最重要的三命令,它們以其強大的功能和廣泛的應用場景而聞名。這三工具的組合使用幾乎可以完美應對Shell中的數據分析場景,因此被統稱為Linux三劍客。
    的頭像 發表于 03-03 10:37 ?413次閱讀

    FPGA圖像處理基礎----實現緩存卷積窗口

    像素行與像素窗口 圖像是由一個個像素點構成的,對于幅480*272大小的圖片來說,其寬度是480,高度是272。在使用FPGA進行圖像
    的頭像 發表于 02-07 10:43 ?785次閱讀
    FPGA<b class='flag-5'>圖像</b>處理基礎----實現緩存卷積窗口

    關于cypress 3014輸出rgb24圖像

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

    AD7616輸出異常,導致后續控制的IGBT炸掉怎么解決?

    AD7616在正常工作30小時后出現輸出保持狀態,后經過段時間,驅動和FPGA有交互,但輸出異常,導致后續控制的IGBT炸掉。目前AD7616是在硬件并口且未使用復位功能。初步判斷是外部干擾造成的AD7616輸出異常,想咨詢
    發表于 12-19 06:32

    一個月速成python+OpenCV圖像處理

    適用于哪些場景,然后通過Python編寫代碼來實現這些算法,并應用于實際項目中,實現圖像的檢測、識別、分類、定位、測量等目標。本文將介紹高效學習Python+O
    的頭像 發表于 11-29 18:27 ?441次閱讀
    <b class='flag-5'>一個</b>月速成python+OpenCV<b class='flag-5'>圖像</b>處理

    關于濾波器的問題

    想問一下關于濾波器的問題 http://www.gz.wiki/http://www.gz.wiki/
    發表于 11-12 21:43

    使用Python進行圖像處理

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

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

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

    DSP教學實驗箱_數字圖像處理操作_案例分享:5-13 灰度圖像二值化

    、實驗目的 學習灰度圖像二值化的原理,掌握圖像的讀取方法,并實現在LCD上顯示二值化前后的圖像。 二、實驗原理 圖像二值化
    發表于 07-25 15:03

    圖像邊緣檢測系統的設計流程

    圖像邊緣檢測系統的設計流程是涉及多個步驟的復雜過程,它旨在從圖像中提取出重要的結構信息,如邊界、輪廓等。這些邊緣信息對于圖像分析、機器視
    的頭像 發表于 07-17 16:39 ?722次閱讀

    圖像分割和語義分割的區別與聯系

    、亮度等。圖像分割的目的是將圖像中感興趣的部分與背景分離,以便進行進步的處理和分析。 1.1 圖像分割的類型 圖像分割可以分為以下幾類:
    的頭像 發表于 07-17 09:55 ?1922次閱讀

    圖像檢測和圖像識別的原理、方法及應用場景

    圖像檢測和圖像識別是計算機視覺領域的兩重要概念,它們在許多應用場景中發揮著關鍵作用。 1. 定義 1.1 圖像檢測 圖像檢測(Object
    的頭像 發表于 07-16 11:19 ?6899次閱讀

    圖像識別算法的核心技術是什么

    圖像識別算法是計算機視覺領域的重要研究方向,其目標是使計算機能夠像人類樣理解和識別圖像中的內容。
    的頭像 發表于 07-16 11:02 ?1294次閱讀

    圖像識別技術的原理是什么

    圖像識別技術是種利用計算機視覺和機器學習技術對圖像進行分析和理解的技術。它可以幫助計算機識別和理解圖像中的對象、場景和活動。 圖像預處理
    的頭像 發表于 07-16 10:46 ?2502次閱讀
    主站蜘蛛池模板: 欧美日韩影院 | 日韩毛片大全免费高清 | 视频在线观看网站免费 | 狠狠色欧美亚洲狠狠色www | 国产caoni111在线观看视频 | 看毛片的网站 | 久久天天躁狠狠躁狠狠躁 | 在线观看视频网站 | 久操成人| 曰曰摸天天摸人人看久久久 | 天堂网在线免费 | 免费在线公开视频 | 天堂网资源www | 色黄视频 | 伊人干| 亚洲不卡免费视频 | 午夜看片在线观看 | 张柏芝三级无删减在线观看 | 亚洲欧美一区二区三区四区 | 精品日韩一区二区三区 | 91久久精品青青草原伊人 | 久久视频精品36线视频在线观看 | a久久久久一级毛片护士免费 | 奇米影视久久 | 91精品国产色综合久久不卡蜜 | 午夜久久免影院欧洲 | 激情理论 | 黄黄的网站在线观看 | 欧美日韩国产一区 | 九九热免费观看 | 成人种子 | 在线免费亚洲 | 亚洲精品网站日本xxxxxxx | 男人不识本网站上遍色站也枉然 | 手机看片神马午夜 | 午夜寂寞在线一级观看免费 | 免费又黄又爽的禁片视频 | 视频h在线观看 | 人人草人人插 | 四虎影视色费永久在线观看 | 91精选视频在线观看 |