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

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

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

基于OpenCV如何提取中心線

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

問題

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

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

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

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

Python環(huán)境下安裝skimage圖像處理包與opencv計(jì)算機(jī)視覺包,只需要分別執(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ò)展包。此外還可以通過形態(tài)學(xué)的膨脹與腐蝕來實(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é)果如下:

編輯:jq

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

    關(guān)注

    2

    文章

    1074

    瀏覽量

    40225
  • 骨架
    +關(guān)注

    關(guān)注

    0

    文章

    11

    瀏覽量

    8372
  • OpenCV
    +關(guān)注

    關(guān)注

    29

    文章

    622

    瀏覽量

    41036

原文標(biāo)題:基于OpenCV實(shí)戰(zhàn):提取中心線

文章出處:【微信號(hào):vision263com,微信公眾號(hào):新機(jī)器視覺】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    OpenCV圖像識(shí)別C++代碼

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

    opencv-python和opencv一樣嗎

    不一樣。OpenCV(Open Source Computer Vision Library)是一個(gè)開源的計(jì)算機(jī)視覺和機(jī)器學(xué)習(xí)軟件庫,它提供了大量的圖像和視頻處理功能。OpenCV
    的頭像 發(fā)表于 07-16 10:38 ?333次閱讀

    opencv的主要功能有哪些

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

    FPC彎曲半徑不合理為什么會(huì)導(dǎo)致斷裂呢?

    在FPC在彎曲時(shí),其中心線兩邊所受的應(yīng)力類型是不一樣的。彎曲曲面的內(nèi)側(cè)是壓力,外側(cè)是拉力。
    的頭像 發(fā)表于 01-10 11:38 ?571次閱讀
    FPC彎曲半徑不合理為什么會(huì)導(dǎo)致斷裂呢?

    AD7400的采樣范圍要和同步信號(hào)中心線對(duì)齊,時(shí)鐘和同步信號(hào)時(shí)鐘怎么設(shè)置?

    AD7400的時(shí)鐘是10MHZ,處理器是TI的28335時(shí)鐘是150MHZ,AD7400的采樣范圍要和同步信號(hào)中心線對(duì)齊,AD7400的時(shí)鐘和同步信號(hào)時(shí)鐘怎么設(shè)置。
    發(fā)表于 12-11 08:13

    OpenCV4.8 CUDA編程代碼教程

    OpenCV4支持通過GPU實(shí)現(xiàn)CUDA加速執(zhí)行,實(shí)現(xiàn)對(duì)OpenCV圖像處理程序的加速運(yùn)行,當(dāng)前支持加速的模塊包括如下。
    的頭像 發(fā)表于 12-05 09:56 ?793次閱讀
    <b class='flag-5'>OpenCV</b>4.8 CUDA編程代碼教程

    汽輪機(jī)連通管修前分析漏真空原因

    低壓外缸與密封隔板連接法蘭平面標(biāo)高處至轉(zhuǎn)子中心線3 005 mm,低壓內(nèi)缸與密封隔板連接法蘭平面標(biāo)高處至轉(zhuǎn)子中心線2 998.5 mm,差值即為密封隔板冷緊值6.5 mm。實(shí)際測(cè)量密封隔板兩側(cè)法蘭水平高度不一,差值約為6 mm。
    的頭像 發(fā)表于 11-30 14:36 ?676次閱讀
    汽輪機(jī)連通管修前分析漏真空原因

    OpenCV對(duì)openEuler提供上游原生支持

    2023年11月17日,OpenCV社區(qū)正式接納openEuler作為持續(xù)集成(Continuous Integration,CI)系統(tǒng)的操作系統(tǒng)之一,對(duì)openEuler提供上游原生支持
    的頭像 發(fā)表于 11-20 09:14 ?654次閱讀

    OpenCV實(shí)驗(yàn)大師平臺(tái)安裝指南

    工程與技術(shù)培訓(xùn)得痛點(diǎn)深深教育了我,讓我知道“工欲善其事必先利其器”。通過一年多得努力開發(fā)與不斷打磨,一款能夠提升OpenCV教學(xué)質(zhì)量與OpenCV工程化開發(fā)質(zhì)量與速度的工具軟件成功出現(xiàn)了。它就
    的頭像 發(fā)表于 11-13 11:43 ?710次閱讀
    <b class='flag-5'>OpenCV</b>實(shí)驗(yàn)大師平臺(tái)安裝指南

    總結(jié)鉆孔步驟、提高鉆孔精度的方法

    劃線:鉆孔前,首要了解圖樣要求,按照鉆孔的基本標(biāo)準(zhǔn)要求,運(yùn)用工具劃出孔位置的中心線中心線一定要清楚準(zhǔn)確,且越細(xì)越好,劃完后要用游標(biāo)卡尺或鋼板尺進(jìn)行測(cè)量。
    的頭像 發(fā)表于 11-12 10:25 ?920次閱讀
    總結(jié)鉆孔步驟、提高鉆孔精度的方法

    OpenCV初學(xué)者如何提取這些不規(guī)則的ROI區(qū)域

    ,而且這些ROI區(qū)域往往不是矩形區(qū)域,一般都是不規(guī)則的多邊形區(qū)域,很多OpenCV初學(xué)者都不知道如何提取這些不規(guī)則的ROI區(qū)域。
    的頭像 發(fā)表于 10-31 14:51 ?728次閱讀

    OpenCV基礎(chǔ)知識(shí)入門

    OpenCV是計(jì)算機(jī)視覺中最受歡迎的庫,最初由intel使用C和C ++進(jìn)行開發(fā)的,現(xiàn)在也可以在python中使用。該庫是一個(gè)跨平臺(tái)的開源庫,是免費(fèi)使用的。OpenCV庫是一個(gè)高度優(yōu)化的庫,主要關(guān)注實(shí)時(shí)應(yīng)用程序。
    的頭像 發(fā)表于 10-29 11:29 ?632次閱讀
    <b class='flag-5'>OpenCV</b>基礎(chǔ)知識(shí)入門

    openCV邊緣檢測(cè)原理是什么?

    openCV是通過什么原理來實(shí)現(xiàn)邊緣檢測(cè)的
    發(fā)表于 10-10 06:21

    OpenCV 如何加載圖片

    之前也寫過一些 OpenCV 的文章,最近正好在考慮 寫一個(gè) OpenCV相關(guān)的工具,目前還是在開發(fā)過程中,邊開發(fā)邊更新。預(yù)計(jì)會(huì)持續(xù)一段時(shí)間。目前的想法是把 OpenCV 的 API 在這個(gè)工具上都
    的頭像 發(fā)表于 10-09 15:01 ?581次閱讀

    OpenCV中的BGR格式,在libyuv中對(duì)應(yīng)的那個(gè)格式?OpenCV中的RGB格式呢?

    OpenCV中的BGR格式,在libyuv中對(duì)應(yīng)的那個(gè)格式?OpenCV中的RGB格式呢?
    發(fā)表于 09-19 06:00