国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

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

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

3天內不再提示

基于OpenCV如何提取中心線

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

掃碼添加小助手

加入工程師交流群

問題

前幾天有個人問了我一個問題,問題是這樣的,他有如下的一張二值圖像:

怎么得到白色Blob中心線,他希望的效果如下:

顯然OpenCV中常見的輪廓分析無法獲得上面的中心紅色線段,本質上這個問題是如何提取二值對象的骨架,提取骨架的方法在OpenCV的擴展模塊中,另外skimage包也支持圖像的骨架提取。這里就分別基于OpenCV擴展模塊與skimage包來完成骨架提取,得到上述圖示的中心線。

01安裝skimage與opencv擴展包

Python環境下安裝skimage圖像處理包與opencv計算機視覺包,只需要分別執行下面兩行命令:

pip install opencv-contrib-pythonpip install skimage

導入使用

from skimage import morphology import cv2 as cv

02使用skimage實現骨架提取

有兩個相關的函數實現二值圖像的骨架提取,一個是基于距離變換實現的medial_axis方法;另外一個是基于thin的skeletonize骨架提取方法。兩個方法的代碼實現分別如下:

1def skeleton_demo(image):

2 gray = cv.cvtColor(image, cv.COLOR_BGR2GRAY)

3 ret, binary = cv.threshold(gray, 0, 255, cv.THRESH_BINARY | cv.THRESH_OTSU)

4 binary[binary == 255] = 1

5 skeleton0 = morphology.skeletonize(binary)

6 skeleton = skeleton0.astype(np.uint8) * 255

7 cv.imshow(“skeleton”, skeleton)

8 cv.waitKey(0)

9 cv.destroyAllWindows()

10

11

12def medial_axis_demo(image):

13 gray = cv.cvtColor(image, cv.COLOR_BGR2GRAY)

14 ret, binary = cv.threshold(gray, 0, 255, cv.THRESH_BINARY | cv.THRESH_OTSU)

15 binary[binary == 255] = 1

16 skel, distance = morphology.medial_axis(binary, return_distance=True)

17 dist_on_skel = distance * skel

18 skel_img = dist_on_skel.astype(np.uint8)*255

19 contours, hireachy = cv.findContours(skel_img, cv.RETR_EXTERNAL, cv.CHAIN_APPROX_SIMPLE)

20 cv.drawContours(image, contours, -1, (0, 0, 255), 1, 8)

21

22 cv.imshow(“result”, image)

23 cv.waitKey(0)

24 cv.destroyAllWindows()

03使用OpenCV實現骨架提取

OpenCV的圖像細化的骨架提取方法在擴展模塊中,因此需要直接安裝opencv-python的擴展包。此外還可以通過形態學的膨脹與腐蝕來實現二值圖像的骨架提取,下面的代碼實現就是分別演示了基于OpenCV的兩種骨架提取方法。代碼分別如下:

1def morph_find(image):

2 gray = cv.cvtColor(image, cv.COLOR_BGR2GRAY)

3 ret, binary = cv.threshold(gray, 0, 255, cv.THRESH_BINARY | cv.THRESH_OTSU)

4 kernel = cv.getStructuringElement(cv.MORPH_CROSS, (3, 3))

5 finished = False

6 size = np.size(binary)

7 skeleton = np.zeros(binary.shape, np.uint8)

8 while (not finished):

9 eroded = cv.erode(binary, kernel)

10 temp = cv.dilate(eroded, kernel)

11 temp = cv.subtract(binary, temp)

12 skeleton = cv.bitwise_or(skeleton, temp)

13 binary = eroded.copy()

14

15 zeros = size - cv.countNonZero(binary)

16 if zeros == size:

17 finished = True

18

19 contours, hireachy = cv.findContours(skeleton, cv.RETR_EXTERNAL, cv.CHAIN_APPROX_SIMPLE)

20 cv.drawContours(image, contours, -1, (0, 0, 255), 1, 8)

21 cv.imshow(“skeleton”, image)

22 cv.waitKey(0)

23 cv.destroyAllWindows()

24

25

26def thin_demo(image):

27 gray = cv.cvtColor(image, cv.COLOR_BGR2GRAY)

28 ret, binary = cv.threshold(gray, 0, 255, cv.THRESH_BINARY | cv.THRESH_OTSU)

29 thinned = cv.ximgproc.thinning(binary)

30 contours, hireachy = cv.findContours(thinned, cv.RETR_EXTERNAL, cv.CHAIN_APPROX_SIMPLE)

31 cv.drawContours(image, contours, -1, (0, 0, 255), 1, 8)

32 cv.imshow(“thin”, image)

33 cv.waitKey(0)

34 cv.destroyAllWindows()

運行結果如下:

編輯:jq

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

    關注

    2

    文章

    1096

    瀏覽量

    42325
  • 骨架
    +關注

    關注

    0

    文章

    12

    瀏覽量

    8520
  • OpenCV
    +關注

    關注

    33

    文章

    652

    瀏覽量

    44778

原文標題:基于OpenCV實戰:提取中心線

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

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    labview 階梯幅值的提取

    新手請教,階梯幅值的提取。如圖,把每步階梯的幅值提取出來。謝謝*附件:階梯幅值提取.rar
    發表于 02-28 14:41

    沒有專利的opencv-python 版本

    ) 視頻處理 視頻讀取/寫入、幀提取、運動檢測(背景差分) 繪圖功能 畫直線/矩形/圓、添加文字、標注關鍵點 關鍵總結: 對 Python 3.13 來說,最優選擇是安裝 opencv
    發表于 12-13 12:37

    Amphenol FCI Basics MicroSpaceXS? 提取工具解析

    Amphenol FCI Basics MicroSpaceXS? 提取工具解析 在電子工程師的日常工作中,束返工是一個常見的任務。而要高效、安全地完成束返工,一款合適的提取工具至
    的頭像 發表于 12-11 16:00 ?400次閱讀

    架——數據中心的“隱形交通指揮官”

    在數據中心、服務器機房等高密度布線場景中,理架如同一位“隱形交通指揮官”,通過科學管理線纜走向,確保數據傳輸的暢通無阻。它不僅是布線系統的“美容師”,更是保障網絡穩定、提升運維效率的關鍵工具。 一
    的頭像 發表于 11-07 11:25 ?412次閱讀

    零成本鋼鐵俠手套!樹莓派+OpenCV 秒變手勢遙控器!

    大家好,這是一個樹莓派和OpenCV的連載專題。使用樹莓派與OpenCV實現姿態估計和面部特征點追蹤使用樹莓派與OpenCV實現面部和運動追蹤的云臺系統使用樹莓派和OpenCV實現手部
    的頭像 發表于 08-16 16:16 ?1270次閱讀
    零成本鋼鐵俠手套!樹莓派+<b class='flag-5'>OpenCV</b> 秒變手勢遙控器!

    如何使用樹莓派與OpenCV實現面部和運動追蹤的云臺系統?

    大家好,這是一個樹莓派和OpenCV的連載專題。使用樹莓派與OpenCV實現姿態估計和面部特征點追蹤使用樹莓派與OpenCV實現面部和運動追蹤的云臺系統使用樹莓派和OpenCV實現手部
    的頭像 發表于 08-14 17:45 ?1561次閱讀
    如何使用樹莓派與<b class='flag-5'>OpenCV</b>實現面部和運動追蹤的云臺系統?

    如何使用樹莓派+OpenCV實現姿態估計和面部特征點追蹤?

    大家好,這是一個樹莓派和OpenCV的連載專題。使用樹莓派與OpenCV實現姿態估計和面部特征點追蹤使用樹莓派與OpenCV實現面部和運動追蹤的云臺系統使用樹莓派和OpenCV實現手部
    的頭像 發表于 08-13 17:44 ?1305次閱讀
    如何使用樹莓派+<b class='flag-5'>OpenCV</b>實現姿態估計和面部特征點追蹤?

    【GM-3568JHF開發板免費體驗】OpenCV開發環境安裝和計數程序開發

    檢測、色彩轉換)、視頻分析(如運動檢測、目標跟蹤)、特征提取(如 SIFT 、 ORB 算法)、機器學習(如 SVM 、 決策樹 )等。其跨平臺特性使其能在 Linux 、 Windows
    發表于 08-09 13:30

    【GM-3568JHF開發板免費體驗】OpenCV 視頻目標跟蹤 ( CamShift)

    目標區域的質心。 3)移動窗口:將窗口中心移動到質心位置。 4)調整窗口大小和方向:根據目標的尺寸和方向調整窗口。 5)迭代:重復步驟 2 到 4,直到窗口中心不再變化或達到最大迭代次數。 OpenCV
    發表于 08-09 13:19

    如何板端編譯OpenCV并搭建應用--基于瑞芯微米爾RK3576開發板

    本文將介紹基于米爾電子MYD-LR3576開發板(米爾基于瑞芯微 RK3576開發板)的板端編譯OpenCV及環境搭建方案的開發測試。摘自優秀創作者-短笛君 RK3576具有如下配置: 4
    發表于 08-08 17:14

    編譯opencv_camera_test找不到opencv.hpp怎么解決?

    1.取消makefile中的注釋 2.在k230_sdk目錄下進入docker環境后使用make mpp-apps編譯 期待結果和實際結果 期待得到opencv_camera_test.elf文件
    發表于 06-23 06:14

    如何在k230上運行OpenCV的代碼?

    如何在k230上運行OpenCV的代碼
    發表于 06-17 06:06

    控制中心開機后無法識別CYUSB3014,除非重新插入USB,這是怎么回事?

    和 PC 的電源,或者僅關閉 PCBA 的電源時,控制中心偶爾會在開機后顯示無設備。 遇到這種情況,只能把USB3.0的拔掉再插上去,就好了。 添加:PC的操作系統是win10。 如下情況就不行: 接下來重新插上電源就OK了。
    發表于 05-12 06:40

    為LSDK構建opencv時遇到的問題求解

    我正在嘗試使用 flex-builder 來運行 bld -c opencv -r ubuntu:桌面 我想要最新版本的 OpenCV。在我的 sdk.yml 文件中,我將 opencv
    發表于 03-26 08:26

    使用OpenCV保存從攝像頭捕獲的視頻時更改顏色輸出視頻收到警告怎么解決?

    保存了從配備 OpenCV* 的攝像頭捕獲的視頻。 生成更改的顏色輸出視頻。 收到警告:[ INFO:0] global .。/opencv/modules/core/src/utils
    發表于 03-05 07:20