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

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

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

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

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

新機(jī)器視覺(jué) ? 來(lái)源:AI算法與圖像處理 ? 作者:AI算法與圖像處理 ? 2021-04-26 13:49 ? 次閱讀

問(wèn)題

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

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

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

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

    瀏覽量

    8766
  • OpenCV
    +關(guān)注

    關(guān)注

    31

    文章

    635

    瀏覽量

    41563
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    RK3568 + OpenCV 會(huì)碰撞出什么火花?案例詳解:2-1 基于OpenCV的畫(huà)線(xiàn)實(shí)驗(yàn)

    一、實(shí)驗(yàn)?zāi)康?本節(jié)視頻的目的是了解OpenCV的作用并通過(guò)OpenCV實(shí)現(xiàn)畫(huà)線(xiàn)。 二、實(shí)驗(yàn)原理 OpenCV 開(kāi)放源代碼計(jì)算機(jī)視覺(jué)庫(kù) OpenCV(Open source Comput
    發(fā)表于 12-03 14:09

    模塊與電模塊的區(qū)別 光模塊在數(shù)據(jù)中心的應(yīng)用

    在現(xiàn)代數(shù)據(jù)中心的構(gòu)建和運(yùn)營(yíng)中,數(shù)據(jù)傳輸?shù)乃俣群托手陵P(guān)重要。為了滿(mǎn)足日益增長(zhǎng)的數(shù)據(jù)傳輸需求,數(shù)據(jù)中心采用了多種技術(shù)來(lái)優(yōu)化網(wǎng)絡(luò)性能。其中,光模塊和電
    的頭像 發(fā)表于 12-02 14:36 ?567次閱讀

    什么是膜壓方線(xiàn)?

    壓方線(xiàn)是一種用于新能源磁性元件繞組的絕緣線(xiàn)材,具有高電壓穩(wěn)定性、小體積和高功率等優(yōu)勢(shì)。 膜壓方線(xiàn)的結(jié)構(gòu)外層是高溫膠帶,內(nèi)層是多芯漆包線(xiàn)或成品鐵氟龍絕緣
    的頭像 發(fā)表于 10-16 11:33 ?296次閱讀
    什么是膜<b class='flag-5'>包</b>壓方<b class='flag-5'>線(xiàn)</b>?

    【龍芯2K0300蜂鳥(niǎo)板試用】5 搭建opencv開(kāi)發(fā)環(huán)境

    buildroot上需要打開(kāi)opencv,將其編譯進(jìn)系統(tǒng)中,如下所示 測(cè)試可行性 測(cè)試是否編譯成功,通過(guò)獲取usb攝像頭的視頻來(lái)完成,本來(lái)是想通過(guò)qt的multimedia來(lái)實(shí)現(xiàn),無(wú)奈k20300平臺(tái)
    發(fā)表于 08-27 15:08

    opencv-python和opencv一樣嗎

    -Python是OpenCV的一個(gè)Python語(yǔ)言接口,它允許開(kāi)發(fā)者使用Python語(yǔ)言來(lái)調(diào)用OpenCV庫(kù)的功能。 雖然OpenCVOpenCV
    的頭像 發(fā)表于 07-16 10:38 ?1405次閱讀

    opencv的主要功能有哪些

    OpenCV(Open Source Computer Vision Library)是一個(gè)開(kāi)源的計(jì)算機(jī)視覺(jué)庫(kù),提供了大量的計(jì)算機(jī)視覺(jué)算法和工具。以下是OpenCV的主要功能: 圖像處理
    的頭像 發(fā)表于 07-16 10:35 ?1766次閱讀

    什么是機(jī)器視覺(jué)opencv?它有哪些優(yōu)勢(shì)?

    機(jī)器視覺(jué)(Machine Vision)是一種利用計(jì)算機(jī)和圖像處理技術(shù)來(lái)模擬人類(lèi)視覺(jué)系統(tǒng)的功能,實(shí)現(xiàn)對(duì)圖像的識(shí)別、分析和理解的技術(shù)。OpenCV(Open Source Computer
    的頭像 發(fā)表于 07-16 10:33 ?902次閱讀

    三菱fx系列plc擴(kuò)展模塊怎么配置

    三菱FX系列PLC是工業(yè)自動(dòng)化領(lǐng)域中非常受歡迎的一種控制器,具有高度的可靠性和靈活性。為了滿(mǎn)足不同的應(yīng)用需求,F(xiàn)X系列PLC可以通過(guò)擴(kuò)展模塊來(lái)增加其功能和性能。本文將詳細(xì)介紹三菱FX系列PLC
    的頭像 發(fā)表于 06-20 10:20 ?3350次閱讀

    嵌入式學(xué)習(xí)-飛凌ElfBoard ELF 1板卡 - 如何在Ubuntu中編譯OpenCV庫(kù)

    $ ls opencv-3.4.1.tar.gz (3)解壓opencv-3.4.1.tar.gz 源碼: elf@ubuntu:~/work/opencv$ tar xvf
    發(fā)表于 06-07 09:21

    ZCAN總線(xiàn)ZMIO310擴(kuò)展模塊應(yīng)用指南

    ZMIO310系列擴(kuò)展模塊是立式總線(xiàn)擴(kuò)展模塊,可支持EtherCAT和CAN兩種總線(xiàn)方式擴(kuò)展數(shù)字量IO、模擬量AD和DA。 當(dāng)控制器本體的I
    發(fā)表于 04-27 02:45 ?397次閱讀
    ZCAN總線(xiàn)ZMIO310<b class='flag-5'>擴(kuò)展</b><b class='flag-5'>模塊</b>應(yīng)用指南

    為什么無(wú)法安裝CUBE-MX-NFC6擴(kuò)展?

    在官網(wǎng)下載CUBE-MX-NFC6擴(kuò)展以使用NUCLEO-NFC08A1擴(kuò)展板,但是CUBE MX提示非官方擴(kuò)展
    發(fā)表于 03-18 06:10

    模塊化機(jī)房:數(shù)據(jù)中心的未來(lái)

    隨著數(shù)字化轉(zhuǎn)型加速,數(shù)據(jù)中心已成為企業(yè)運(yùn)營(yíng)的核心。傳統(tǒng)的數(shù)據(jù)中心面臨空間利用不足、能源效率低下、擴(kuò)展性差和維護(hù)成本高等問(wèn)題。模塊化機(jī)房應(yīng)運(yùn)而生,它不僅克服了傳統(tǒng)設(shè)計(jì)的局限,還為數(shù)據(jù)
    的頭像 發(fā)表于 03-12 17:26 ?990次閱讀

    cubeMX的擴(kuò)展x-cube-dpower怎么使用?

    x-cube-dpower是新出的一個(gè)數(shù)字電源擴(kuò)展,目前已更新到1.0.2。該如何使用??如果必需配合官方的開(kāi)發(fā)板使用,該如何修改才能更適合用戶(hù)自己的應(yīng)用??
    發(fā)表于 03-08 06:24

    Xbox應(yīng)用新增“游戲中心”功能

    微軟 Xbox 體驗(yàn)高級(jí)產(chǎn)品經(jīng)理 Dylan Meade表示,“游戲中心”便于玩家追蹤游戲進(jìn)展,發(fā)現(xiàn)游戲最新內(nèi)容和擴(kuò)展,與友人聯(lián)機(jī)競(jìng)技,接收開(kāi)發(fā)商的最新新聞等。
    的頭像 發(fā)表于 02-27 14:02 ?775次閱讀

    【米爾-全志T113-i開(kāi)發(fā)板試用】發(fā)布opencv-mobile米爾t113i專(zhuān)享預(yù)編譯

    ); fclose(fp); return (strncmp(buf, \"sun8iw20\", 8) == 0); } opencv highgui 模塊整合t113-i
    發(fā)表于 02-25 20:23
    主站蜘蛛池模板: 久久伊人精品青青草原高清 | 久久久久久午夜精品 | 最新国产厕所 | 韩国三级久久精品 | a免费在线| 亚洲一区二区在线 | va国产 | 欧美zoozzooz在线观看 | 亚洲欧美色视频 | 欧美一欧美一区二三区性 | 高h污快穿文汁水四溅 | 亚洲午夜精品一区二区 | 超刺激gay腐文h文 | 五月天亚洲 | 女18poren69| 欧美黄色tv| 黄页网站视频免费 视频 | 欧美色综合高清视频在线 | 亚洲欧美精品 | 久久综合五月婷婷 | 亚洲国产精品乱码在线观看97 | h网站亚洲 | 免费在线视频你懂的 | 久久www免费人成看片色多多 | 深爱五月综合网 | 美国一级毛片免费看成人 | 日本三级午夜 | 日本黄色爽| 免费久久久久 | sihu免费观看在线高清 | 久久婷婷五综合一区二区 | 在线高清国产 | 日本免费人成黄页在线观看视频 | 唯美久草 | www.淫.com| 免费可以看黄的视频 s色 | 亚洲欧美日韩另类精品一区二区三区 | 免费拍拍视频 | 特黄毛片 | 免费在线观看的网站 | 色橹橹 |