91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

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

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

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

OpenCV中幾何形狀識別與測量

OpenCV學(xué)堂 ? 來源:OpenCV學(xué)堂 ? 作者:OpenCV學(xué)堂 ? 2022-06-02 15:31 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

OpenCV中幾何形狀識別與測量

經(jīng)常看到有學(xué)習(xí)OpenCV不久的人提問,如何識別一些簡單的幾何形狀與它們的顏色,其實(shí)通過OpenCV的輪廓發(fā)現(xiàn)與幾何分析相關(guān)的函數(shù),只需不到100行的代碼就可以很好的實(shí)現(xiàn)這些簡單幾何形狀識別與對象測量相關(guān)操作。本文就會演示給大家如何通過OpenCV 輪廓發(fā)現(xiàn)與幾何分析相關(guān)函數(shù)實(shí)現(xiàn)如下功能:

幾何形狀識別(識別三角形、四邊形/矩形、多邊形、圓)

計(jì)算幾何形狀面積與周長、中心位置

提取幾何形狀的顏色

在具體代碼實(shí)現(xiàn)與程序演示之前,我們先要搞清楚一些概念。

一:基本概念與函數(shù)介紹

1. 輪廓(contours)

什么是輪廓,簡單說輪廓就是一些列點(diǎn)相連組成形狀、它們擁有同樣的顏色、輪廓發(fā)現(xiàn)在圖像的對象分析、對象檢測等方面是非常有用的工具,在OpenCV中使用輪廓發(fā)現(xiàn)相關(guān)函數(shù)時(shí)候要求輸入圖像是二值圖像,這樣便于輪廓提取、邊緣提取等操作。輪廓發(fā)現(xiàn)的函數(shù)與參數(shù)解釋如下:

findContours(image, mode, method, contours=None, hierarchy=None, offset=None)

- image輸入/輸出的二值圖像

- mode 返回輪廓的結(jié)構(gòu)、可以是List、Tree、External

- method 輪廓點(diǎn)的編碼方式,基本是基于鏈?zhǔn)骄幋a

- contours 返回的輪廓集合

- hieracrchy 返回的輪廓層次關(guān)系

- offset 點(diǎn)是否有位移

2. 多邊形逼近

多邊形逼近,是通過對輪廓外形無限逼近,刪除非關(guān)鍵點(diǎn)、得到輪廓的關(guān)鍵點(diǎn),不斷逼近輪廓真實(shí)形狀的方法,OpenCV中多邊形逼近的函數(shù)與參數(shù)解釋如下:

approxPolyDP(curve, epsilon, closed, approxCurve=None)

- curve 表示輸入的輪廓點(diǎn)集合

- epsilon 表示逼近曲率,越小表示相似逼近越厲害

- close 是否閉合

3. 幾何距計(jì)算

圖像幾何距是圖像的幾何特征,高階幾何距中心化之后具有特征不變性,可以產(chǎn)生Hu距輸出,用于形狀匹配等操作,這里我們通過計(jì)算一階幾何距得到指定輪廓的中心位置,計(jì)算幾何距的函數(shù)與參數(shù)解釋如下:

moments(array, binaryImage=None)

- array表示指定輸入輪廓

- binaryImage默認(rèn)為None

二:代碼實(shí)現(xiàn)與演示

基于輪廓發(fā)現(xiàn)與多邊形逼近、幾何距實(shí)現(xiàn)幾何形狀識別與對象測量,測量時(shí)候還用到另外兩個(gè)相關(guān)API分別是計(jì)算輪廓的周長與面積。具體用法在代碼中體現(xiàn)。整個(gè)代碼實(shí)現(xiàn)分為如下幾步完成:1.圖像二值化

# 二值化圖像

print("start to detect lines... ")

gray = cv.cvtColor(frame, cv.COLOR_BGR2GRAY)

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

cv.imshow("input image", frame)

2.輪廓發(fā)現(xiàn)

out_binary, contours, hierarchy = cv.findContours(binary, cv.RETR_EXTERNAL, cv.CHAIN_APPROX_SIMPLE)

for cnt in range(len(contours)):

# 提取與繪制輪廓

cv.drawContours(result, contours, cnt, (0, 255, 0), 2)

3.幾何形狀識別

# 輪廓逼近

epsilon = 0.01 * cv.arcLength(contours[cnt], True)

approx = cv.approxPolyDP(contours[cnt], epsilon, True)

# 分析幾何形狀

corners = len(approx)

shape_type = ""

if corners == 3:

count = self.shapes['triangle']

count = count+1

self.shapes['triangle'] = count

shape_type = "三角形"

if corners == 4:

count = self.shapes['rectangle']

count = count + 1

self.shapes['rectangle'] = count

shape_type = "矩形"

if corners >= 10:

count = self.shapes['circles']

count = count + 1

self.shapes['circles'] = count

shape_type = "圓形"

if 4 < corners < 10:

count = self.shapes['polygons']

count = count + 1

self.shapes['polygons'] = count

shape_type = "多邊形"

4.測量周長、面積、計(jì)算中心

# 求解中心位置

mm = cv.moments(contours[cnt])

cx = int(mm['m10'] / mm['m00'])

cy = int(mm['m01'] / mm['m00'])

cv.circle(result, (cx, cy), 3, (0, 0, 255), -1)

# 計(jì)算面積與周長

p = cv.arcLength(contours[cnt], True)

area = cv.contourArea(contours[cnt])

5.顏色提取

# 顏色分析

color = frame[cy][cx]

color_str = "(" + str(color[0]) + ", " + str(color[1]) + ", " + str(color[2]) + ")"

運(yùn)行顯示原圖如下:

a8ed07b0-e191-11ec-ba43-dac502259ad0.png

分析結(jié)果:

a923e762-e191-11ec-ba43-dac502259ad0.png

控制臺輸出:

a9471d18-e191-11ec-ba43-dac502259ad0.png

審核編輯 :李倩

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

    關(guān)注

    0

    文章

    37

    瀏覽量

    12662
  • 測量
    +關(guān)注

    關(guān)注

    10

    文章

    5632

    瀏覽量

    116719
  • OpenCV
    +關(guān)注

    關(guān)注

    33

    文章

    652

    瀏覽量

    44783

原文標(biāo)題:OpenCV中幾何形狀識別與測量

文章出處:【微信號:CVSCHOOL,微信公眾號:OpenCV學(xué)堂】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

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

    多種類幾何尺寸集成智能儀器定制 一站式解決產(chǎn)線多維度測量需求

    關(guān)鍵詞:幾何尺寸測量儀,智能儀器,定制儀器,測寬測厚儀,測寬測長儀,直線度外徑測量儀 在現(xiàn)代化生產(chǎn)線上,幾何尺寸測量是保障產(chǎn)品精度、控制生產(chǎn)
    發(fā)表于 10-09 13:50

    【EASY EAI Orin Nano開發(fā)板試用體驗(yàn)】PP-OCRV5文字識別實(shí)例搭建與移植

    /3rdparty/rknpu2/Linux/aarch64/:/home/proj-RK3588/opencv_lib_46/ 然后編譯野火魯班貓的例程的cpp文件夾,生成可以執(zhí)行的程序并運(yùn)行,在第二個(gè)
    發(fā)表于 08-18 16:57

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

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

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

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

    如何使用樹莓派+OpenCV實(shí)現(xiàn)姿態(tài)估計(jì)和面部特征點(diǎn)追蹤?

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

    用樹莓派 + OpenCV 打造人臉識別技術(shù)!

    在本指南中,我們將教您如何使用OpenCV和面部識別庫(兩個(gè)出色的開源項(xiàng)目)設(shè)置樹莓派來檢測和識別面部。在這個(gè)設(shè)置,所有的數(shù)據(jù)和處理都將在Pi上本地執(zhí)行,這意味著您的所有面部和數(shù)據(jù)都
    的頭像 發(fā)表于 07-29 17:27 ?1349次閱讀
    用樹莓派 + <b class='flag-5'>OpenCV</b> 打造人臉<b class='flag-5'>識別</b>技術(shù)!

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

    -mobile-test ./opencv-mobile-test 生成 200x200 尺寸的 out.jpg 圖像,即實(shí)現(xiàn)圖片壓縮。 該測試工程可結(jié)合物體識別模型,實(shí)現(xiàn)輸入圖像的尺寸調(diào)整,為之后的推理和處理等流程提供幫助。 總結(jié)
    發(fā)表于 07-11 13:48

    三坐標(biāo)微米級測量精度,高精度檢測液壓支架導(dǎo)向套的幾何公差尺寸

    Mars Classic 10158 三坐標(biāo)測量機(jī)可以測量各種復(fù)雜幾何特征,滿足客戶對閥體全尺寸檢測的需求;能實(shí)現(xiàn)微米級的高精度測量,滿足導(dǎo)向套關(guān)鍵尺寸的高精度檢測需求;自動(dòng)
    的頭像 發(fā)表于 07-10 13:33 ?782次閱讀
    三坐標(biāo)微米級<b class='flag-5'>測量</b>精度,高精度檢測液壓支架導(dǎo)向套的<b class='flag-5'>幾何</b>公差尺寸

    基于LockAI視覺識別模塊:C++人臉識別

    基本知識講解 1.1 人臉識別簡介 人臉識別是一種利用人的臉部特征進(jìn)行身份識別的生物識別技術(shù)。它通過檢測圖像或視頻的人臉,提取如眼睛、鼻
    發(fā)表于 07-01 12:01

    基于LockAI視覺識別模塊:手寫數(shù)字識別

    (input_mat); 作用:PaddleClas類的一個(gè)函數(shù),用于實(shí)現(xiàn)手寫數(shù)字識別。 參數(shù)說明: input_mat:要識別的圖像。 返回值: 返回一個(gè)包含手寫數(shù)字分類結(jié)果的對象。該
    發(fā)表于 06-30 16:45

    wafer晶圓幾何形貌測量系統(tǒng):厚度(THK)翹曲度(Warp)彎曲度(Bow)等數(shù)據(jù)測量

    在先進(jìn)制程,厚度(THK)翹曲度(Warp)彎曲度(Bow)三者共同決定了晶圓的幾何完整性,是良率提升和成本控制的核心參數(shù)。通過WD4000晶圓幾何形貌測量系統(tǒng)在線檢測,可減少其對芯
    發(fā)表于 05-28 11:28 ?2次下載

    wafer晶圓幾何形貌測量系統(tǒng):厚度(THK)翹曲度(Warp)彎曲度(Bow)等數(shù)據(jù)測量

    在先進(jìn)制程,厚度(THK)翹曲度(Warp)彎曲度(Bow)三者共同決定了晶圓的幾何完整性,是良率提升和成本控制的核心參數(shù)。通過WD4000晶圓幾何形貌測量系統(tǒng)在線檢測,可減少其對芯
    的頭像 發(fā)表于 05-23 14:27 ?1407次閱讀
    wafer晶圓<b class='flag-5'>幾何</b>形貌<b class='flag-5'>測量</b>系統(tǒng):厚度(THK)翹曲度(Warp)彎曲度(Bow)等數(shù)據(jù)<b class='flag-5'>測量</b>

    PanDao:輸入形狀精度參數(shù)

    手工拋光制作測試板(T)進(jìn)行面形偏差測量的傳統(tǒng)技術(shù)(該檢測裝置也見于斐索干涉儀)。 被測表面(S)的面形誤差(表面高度H)是通過將表面的形狀與測試板(T)的標(biāo)準(zhǔn)形狀(通常精度<1/
    發(fā)表于 05-06 08:45

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

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

    CMM三坐標(biāo)測量機(jī)能測量的數(shù)據(jù)

    CMM三坐標(biāo)測量機(jī)能夠測量的數(shù)據(jù)非常廣泛,包括但不限于:幾何元素?cái)?shù)據(jù):如點(diǎn)、線、面、圓、球、圓柱、圓錐等幾何元素的尺寸和形狀數(shù)據(jù)。這些數(shù)據(jù)可
    的頭像 發(fā)表于 03-21 18:49 ?1280次閱讀
    CMM三坐標(biāo)<b class='flag-5'>測量</b>機(jī)能<b class='flag-5'>測量</b>的數(shù)據(jù)