chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

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

基于OpenCV擴(kuò)展模塊與skimage包來(lái)提取中心線

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

掃碼添加小助手

加入工程師交流群

問(wèn)題

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

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

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

01安裝skimage與opencv擴(kuò)展包

Python環(huán)境下安裝skimage圖像處理包與opencv計(jì)算機(jī)視覺(jué)包,只需要分別執(zhí)行下面兩行命令:

pip install opencv-contrib-pythonpip install skimage

導(dǎo)入使用

from skimage import morphology import cv2 as cv

02使用skimage實(shí)現(xiàn)骨架提取

有兩個(gè)相關(guān)的函數(shù)實(shí)現(xiàn)二值圖像的骨架提取,一個(gè)是基于距離變換實(shí)現(xiàn)的medial_axis方法;另外一個(gè)是基于thin的skeletonize骨架提取方法。兩個(gè)方法的代碼實(shí)現(xiàn)分別如下:

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實(shí)現(xiàn)骨架提取

OpenCV的圖像細(xì)化的骨架提取方法在擴(kuò)展模塊中,因此需要直接安裝opencv-python的擴(kuò)展包。此外還可以通過(guò)形態(tài)學(xué)的膨脹與腐蝕來(lái)實(shí)現(xiàn)二值圖像的骨架提取,下面的代碼實(shí)現(xiàn)就是分別演示了基于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()

運(yùn)行結(jié)果如下:

編輯:lyn

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(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)投訴
  • 二值圖像
    +關(guān)注

    關(guān)注

    0

    文章

    14

    瀏覽量

    8913
  • OpenCV
    +關(guān)注

    關(guān)注

    33

    文章

    652

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    沒(méi)有專利的opencv-python 版本

    所有 官方發(fā)布的 opencv-python 核心版本(無(wú) contrib 擴(kuò)展)都無(wú)專利風(fēng)險(xiǎn)——專利問(wèn)題僅存在于 opencv-contrib-python 擴(kuò)展
    發(fā)表于 12-13 12:37

    Amphenol FCI Basics MicroSpaceXS? 提取工具解析

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

    時(shí)鐘是否需要地處理?

    時(shí)鐘是否需要地處理?有沒(méi)有成熟的整改方案參考?
    發(fā)表于 11-21 06:53

    光纖理架:數(shù)據(jù)中心高效運(yùn)維的“隱形冠軍”

    ”。 優(yōu)勢(shì)一:空間利用率提升60%,破解高密度布線難題 傳統(tǒng)理架采用固定式設(shè)計(jì),單層僅支持24-48芯光纖,而新一代模塊化理架通過(guò)分層擴(kuò)展技術(shù),實(shí)現(xiàn)單層192芯高密度布線。以阿里巴
    的頭像 發(fā)表于 10-28 10:03 ?183次閱讀

    KAGA FEI擴(kuò)展低功耗藍(lán)牙模塊產(chǎn)品

    全球領(lǐng)先的短距離無(wú)線模塊供應(yīng)商 KAGA FEI 于近期推出 EC4L10BA1 和 EC4L05BA1,擴(kuò)展其低功耗藍(lán)牙模塊產(chǎn)品。
    的頭像 發(fā)表于 09-03 14:21 ?1567次閱讀

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

    大家好,這是一個(gè)樹(shù)莓派和OpenCV的連載專題。使用樹(shù)莓派與OpenCV實(shí)現(xiàn)姿態(tài)估計(jì)和面部特征點(diǎn)追蹤使用樹(shù)莓派與OpenCV實(shí)現(xiàn)面部和運(yùn)動(dòng)追蹤的云臺(tái)系統(tǒng)使用樹(shù)莓派和OpenCV實(shí)現(xiàn)手部
    的頭像 發(fā)表于 08-16 16:16 ?1133次閱讀
    零成本鋼鐵俠手套!樹(shù)莓派+<b class='flag-5'>OpenCV</b> 秒變手勢(shì)遙控器!

    如何使用樹(shù)莓派與OpenCV實(shí)現(xiàn)面部和運(yùn)動(dòng)追蹤的云臺(tái)系統(tǒng)?

    大家好,這是一個(gè)樹(shù)莓派和OpenCV的連載專題。使用樹(shù)莓派與OpenCV實(shí)現(xiàn)姿態(tài)估計(jì)和面部特征點(diǎn)追蹤使用樹(shù)莓派與OpenCV實(shí)現(xiàn)面部和運(yùn)動(dòng)追蹤的云臺(tái)系統(tǒng)使用樹(shù)莓派和OpenCV實(shí)現(xiàn)手部
    的頭像 發(fā)表于 08-14 17:45 ?1137次閱讀
    如何使用樹(shù)莓派與<b class='flag-5'>OpenCV</b>實(shí)現(xiàn)面部和運(yùn)動(dòng)追蹤的云臺(tái)系統(tǒng)?

    【GM-3568JHF開(kāi)發(fā)板免費(fèi)體驗(yàn)】OpenCV開(kāi)發(fā)環(huán)境安裝和計(jì)數(shù)程序開(kāi)發(fā)

    檢測(cè)、色彩轉(zhuǎn)換)、視頻分析(如運(yùn)動(dòng)檢測(cè)、目標(biāo)跟蹤)、特征提取(如 SIFT 、 ORB 算法)、機(jī)器學(xué)習(xí)(如 SVM 、 決策樹(shù) )等。其跨平臺(tái)特性使其能在 Linux 、 Windows
    發(fā)表于 08-09 13:30

    如何板端編譯OpenCV并搭建應(yīng)用--基于瑞芯微米爾RK3576開(kāi)發(fā)板

    運(yùn)行opencv代碼,來(lái)完成一些視覺(jué)內(nèi)容,充分發(fā)揮該板的性能。要先編譯opencv需要一些預(yù)先的準(zhǔn)備工作首先更新軟件并安裝必要的依賴:sudo apt update sudo apt
    發(fā)表于 08-08 17:14

    【Milk-V Duo S 開(kāi)發(fā)板免費(fèi)體驗(yàn)】SDK編譯、人臉檢測(cè)、OpenCV測(cè)試

    。 OpenCV-mobile OpenCV-mobile 是一個(gè)精簡(jiǎn)版的 OpenCV 庫(kù),通過(guò)調(diào)整編譯參數(shù),刪減部分 OpenCV 源碼,來(lái)
    發(fā)表于 07-11 13:48

    基于LockAI視覺(jué)識(shí)別模塊:C++圖像采集例程

    本文主要演示如何使用LockAI視覺(jué)識(shí)別模塊進(jìn)行視頻流的讀取,同時(shí)使用Edit模塊進(jìn)行圖像傳輸?;A(chǔ)知識(shí)講解1.1OpenCV簡(jiǎn)介OpenCV(OpenSourceComputerVi
    的頭像 發(fā)表于 04-30 18:23 ?667次閱讀
    基于LockAI視覺(jué)識(shí)別<b class='flag-5'>模塊</b>:C++圖像采集例程

    算力魔方IO擴(kuò)展模塊介紹 網(wǎng)絡(luò)篇1

    一,算力魔方簡(jiǎn)介 算力魔方?AIPC是目前市面上唯一的模塊化迷你電腦,在巴掌大小的空間提供強(qiáng)大的AI算力!主機(jī)分為兩個(gè)模塊:第一層計(jì)算模塊與第二層IO擴(kuò)展
    的頭像 發(fā)表于 04-09 14:33 ?928次閱讀
    算力魔方IO<b class='flag-5'>擴(kuò)展</b><b class='flag-5'>模塊</b>介紹 網(wǎng)絡(luò)篇1

    為L(zhǎng)SDK構(gòu)建opencv時(shí)遇到的問(wèn)題求解

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

    如何在OpenVINO?安裝完成提取后手動(dòng)運(yùn)行install.exe文件?

    運(yùn)行 w_openvino_toolkit_p_2021.4.689.exe 安裝。 遇到錯(cuò)誤: Return Code of child process: -1073741571。 安裝窗口在提取后打開(kāi)并立即關(guān)閉。
    發(fā)表于 03-05 07:46

    漢思新材料:金封膠在多領(lǐng)域的應(yīng)用

    漢思新材料:金封膠在多領(lǐng)域的應(yīng)用漢思金封膠是一種高性能的封裝材料,憑借其優(yōu)異的物理化學(xué)特性(如耐高溫、防水、耐腐蝕、抗震動(dòng)等),在多個(gè)領(lǐng)域中展現(xiàn)了廣泛的應(yīng)用。以下是其主要的應(yīng)用
    的頭像 發(fā)表于 02-28 16:11 ?1183次閱讀
    漢思新材料:金<b class='flag-5'>線</b><b class='flag-5'>包</b>封膠在多領(lǐng)域的應(yīng)用