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

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

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

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

基于OpenCV擴展模塊與skimage包來提取中心線

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

掃碼添加小助手

加入工程師交流群

問題

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

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

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

01安裝skimage與opencv擴展包

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

pip install opencv-contrib-pythonpip install skimage

導(dǎo)入使用

from skimage import morphology import cv2 as cv

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

有兩個相關(guān)的函數(shù)實現(xiàn)二值圖像的骨架提取,一個是基于距離變換實現(xiàn)的medial_axis方法;另外一個是基于thin的skeletonize骨架提取方法。兩個方法的代碼實現(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實現(xiàn)骨架提取

OpenCV的圖像細化的骨架提取方法在擴展模塊中,因此需要直接安裝opencv-python的擴展包。此外還可以通過形態(tài)學(xué)的膨脹與腐蝕來實現(xiàn)二值圖像的骨架提取,下面的代碼實現(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()

運行結(jié)果如下:

編輯:lyn

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 二值圖像
    +關(guān)注

    關(guān)注

    0

    文章

    14

    瀏覽量

    8847
  • OpenCV
    +關(guān)注

    關(guān)注

    32

    文章

    642

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

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

    基于LockAI視覺識別模塊:C++圖像采集例程

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

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

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

    為LSDK構(gòu)建opencv時遇到的問題求解

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

    如何在OpenVINO?安裝完成提取后手動運行install.exe文件?

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

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

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

    RK3568 + OpenCV 會碰撞出什么火花?案例詳解:2-1 基于OpenCV的畫線實驗

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

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

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

    諾基亞擴展與微軟Azure的數(shù)據(jù)中心網(wǎng)絡(luò)供應(yīng)協(xié)議

    的進一步鞏固。 作為協(xié)議擴展的重要組成部分,諾基亞將向微軟Azure提供其最新的7250 IXR-10e平臺。該平臺以其卓越的性能、靈活性和可擴展性,在數(shù)據(jù)中心網(wǎng)絡(luò)中發(fā)揮著關(guān)鍵作用。通過提供這一先進平臺,諾基亞旨在助力微軟Azu
    的頭像 發(fā)表于 11-22 13:53 ?542次閱讀

    什么是膜壓方

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

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

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

    Nexperia、東芝和Navitas擴展MOSFET產(chǎn)品以應(yīng)對高效能需求

    公司紛紛擴展了各自的MOSFET產(chǎn)品,以滿足行業(yè)的挑戰(zhàn)和機遇。Navitas、東芝和Nexperia的新型MOSFETNexperia最近擴展了其NextPowe
    的頭像 發(fā)表于 08-27 11:47 ?663次閱讀
    Nexperia、東芝和Navitas<b class='flag-5'>擴展</b>MOSFET產(chǎn)品<b class='flag-5'>線</b>以應(yīng)對高效能需求

    OpenCV圖像識別C++代碼

    安裝OpenCV庫 首先,您需要在您的計算機上安裝OpenCV庫。您可以從OpenCV官網(wǎng)下載預(yù)編譯的庫或從源代碼編譯。安裝完成后,確保將OpenCV的頭文件和庫文件添加到您的項目中。
    的頭像 發(fā)表于 07-16 10:42 ?4489次閱讀

    opencv-python和opencv一樣嗎

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

    opencv的主要功能有哪些

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

    什么是機器視覺opencv?它有哪些優(yōu)勢?

    機器視覺(Machine Vision)是一種利用計算機和圖像處理技術(shù)模擬人類視覺系統(tǒng)的功能,實現(xiàn)對圖像的識別、分析和理解的技術(shù)。OpenCV(Open Source Computer
    的頭像 發(fā)表于 07-16 10:33 ?1337次閱讀
    主站蜘蛛池模板: 好爽~~~~嗯~~~再快点明星 | 农村苗族一级特黄a大片 | 亚洲一区二区三区在线网站 | 荡女妇边被c边呻吟久久 | 四虎影视在线影院4hutv | 你懂的网址免费国产 | 亚州第一视频 | 青青伊人91久久福利精品 | 午夜视频网址 | 天天插综合网 | 色多多黄 | a级男女性高爱潮高清试 | 91国在线啪精品一区 | 波多野结衣久久精品 | 九月婷婷亚洲综合在线 | 亚洲韩国日本欧美一区二区三区 | 色噜噜狠狠大色综合 | 男男扒开后菊惩罚 | 女人色视频 | 一级做a爱片就在线看 | aa视频在线观看 | 日本a级在线 | 三级天堂 | 成人人免费夜夜视频观看 | 毛片污 | 久久综合社区 | 日本一区二区三区四区在线观看 | 苦瓜se影院在线视频网站 | 手机看片1024手机在线观看 | 手机在线一区二区三区 | 欧美午夜寂寞影院安卓列表 | 精品乱人伦一区二区三区 | 免费在线欧美 | 国产精品人人爱一区二区白浆 | 一级日本高清视频免费观看 | 成人欧美精品大91在线 | 婷婷毛片 | 毛片小视频 | 欧美成网| www婷婷 | 国产一区二区三区免费大片天美 |