精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

          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
            +關注

            關注

            30

            文章

            628

            瀏覽量

            41270
          • 檢測圖像
            +關注

            關注

            0

            文章

            3

            瀏覽量

            5530
          • python
            +關注

            關注

            56

            文章

            4782

            瀏覽量

            84468

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

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

          收藏 人收藏

            評論

            相關推薦

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

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

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

            圖像識別技術是種利用計算機視覺和機器學習技術對圖像進行分析和理解的技術。它可以幫助計算機識別和理解圖像中的對象、場景和活動。 圖像預處理
            的頭像 發表于 07-16 10:46 ?834次閱讀

            機器人視覺技術中圖像分割方法有哪些

            機器人視覺技術是人工智能領域的重要分支,它涉及到圖像處理、模式識別、機器學習等多個學科。圖像分割是機器人視覺技術中的
            的頭像 發表于 07-04 11:34 ?787次閱讀

            FPGA設計經驗之圖像處理

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

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

            命令出現失敗(正常),插上SD卡后繼續使用掛載命令還是掛載失敗(不正常) 問題分析: 旦掛載失敗,后續無法繼續掛載,可能和掛載失敗的第次有關,尋找
            發表于 05-30 07:38

            尋找位編程員

            尋找位編程員。請法郵件 j_helmut@163.com
            發表于 04-02 13:34

            尋找能夠PID調節的仿真軟件

            最近想學習些有關PID調節的知識,有沒有些相關資料推薦?文章書籍什么隨便都可以;還有就是尋找幾款有關PID在線調節的網址或者軟件,能夠使我對PID的調節過程有
            發表于 02-29 22:44

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

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

            圖像跟蹤設備發展歷史

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

            關于數字圖像處理的常用技巧

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

            計算機視覺、計算機圖像學和圖像處理詳解

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

            Python調用OpenCV實現圖像腐蝕案例

            圖像的膨脹(Dilation)和腐蝕(Erosion)是兩種基本的形態學運算,主要用來尋找圖像中的極大區域和極小區域。其中膨脹類似于“領域擴張”,將圖像中的高亮區域或白色部分進行擴張,
            的頭像 發表于 12-20 10:20 ?1060次閱讀
            Python調用OpenCV實現<b class='flag-5'>圖像</b>腐蝕案例

            LED透明屏有什么亮點和問題?

            安裝時需要考慮光線的遮擋。為了解決這些問題,LED透明屏應運而生。LED透明屏是種將LED顯示技術與透明材料結合的創新產品,可以實現自然環境和數字信息之間的和諧共存。本文將從亮點和問題兩方面,詳細介紹LED透明屏的特點和使用
            的頭像 發表于 12-09 14:04 ?962次閱讀

            FPGA圖像處理方法

            圖像在采集和傳輸的過程中,通常會產生噪聲,使圖像質量降低,影響后續處理。因此須對圖像進行圖像
            的頭像 發表于 12-02 13:15 ?1075次閱讀

            AD725不顯示輸出圖像是為什么?

            您好,我使用AD725芯片設計了VGA轉AV模塊,PAL制式,外圍電路與芯片手冊致,但是沒有圖像輸出。我想詢問兩問題。1.該芯片是否只適用于隔行信號輸入,對于逐行信號兼容嗎?如果輸入逐行信號會
            發表于 11-28 07:30