佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > OpenCV半小時掌握基本操作之圓圈檢測

OpenCV半小時掌握基本操作之圓圈檢測

熱門標(biāo)簽:美圖手機(jī) 銀行業(yè)務(wù) 鐵路電話系統(tǒng) 網(wǎng)站文章發(fā)布 服務(wù)器配置 智能手機(jī) 檢查注冊表項 呼叫中心市場需求

【OpenCV】⚠️高手勿入! 半小時學(xué)會基本操作 ⚠️ 圓圈檢測

概述

OpenCV 是一個跨平臺的計算機(jī)視覺庫, 支持多語言, 功能強大. 今天小白就帶大家一起攜手走進(jìn) OpenCV 的世界.

霍夫圓變換

霍夫圓變換 (Hough Circle Transform) 的原理和霍夫直線變換類似. 對于一條直線, 我們可以用參數(shù) (r, θ) 表示, 對于圓我們需要三個參數(shù) (x, y, r), 分別代表三個參數(shù) x 圓心, y 圓心, r, 半徑.

代碼實現(xiàn)

因為霍夫圓檢測對噪聲比較敏感, 所以首先要對圖像做中值濾波.

基于效率考慮, Opencv 中實現(xiàn)的霍夫變換圓檢測是基于圖像梯度實現(xiàn), 分為兩步:

檢測變換, 發(fā)現(xiàn)可能的圓心基于第一步的基礎(chǔ)上從候選圓心開始計算最佳半徑大小

格式:

cv2.HoughCircles(image, method, dp, minDist, circles=None, param1=None, param2=None, minRadius=None, maxRadius=None)

參數(shù):

image: 輸入圖像

method: 判別方法, 只有 HOUGH_GRADIENT (計算梯度) 一個方法

dp: 累計閾值

minDist: 間距, 小于間距判斷成一個圓

param1: Canny 邊緣檢測的最大閾值

param2: 在檢測階段圓心累加器閾值, 是否為圓形

例一

import numpy as np
import cv2
from matplotlib import pyplot as plt

# 讀取圖片
image = cv2.imread("map.jpg")
image_copy = image.copy()

# 均值遷移濾波
filter = cv2.pyrMeanShiftFiltering(image, 10, 100)

# 轉(zhuǎn)換成灰度圖
filter_gray = cv2.cvtColor(filter, cv2.COLOR_BGR2GRAY)

# 霍夫曼圓圈檢測
circles = cv2.HoughCircles(filter_gray, cv2.HOUGH_GRADIENT, 1, 20, param1=50, param2=100, minRadius=0, maxRadius=0)
circles = np.uint16(np.around(circles))

# 遍歷
for circle in circles[0, :]:
    cv2.circle(image_copy, (circle[0], circle[1]), circle[2], (0, 0, 255), 2)
    cv2.circle(image_copy, (circle[0], circle[1]), 2, (255, 0, 0), 2)

# 圖片展示
f, ax = plt.subplots(2, 2, figsize=(12, 12))

# 子圖
ax[0, 0].imshow(cv2.cvtColor(image, cv2.COLOR_BGR2RGB))
ax[0, 1].imshow(cv2.cvtColor(filter, cv2.COLOR_BGR2RGB))
ax[1, 0].imshow(filter_gray, "gray")
ax[1, 1].imshow(cv2.cvtColor(image_copy, cv2.COLOR_BGR2RGB))

# 標(biāo)題
ax[0, 0].set_title("original")
ax[0, 1].set_title("image filter")
ax[1, 0].set_title("image gray")
ax[1, 1].set_title("image circle")

plt.show()

# 保存結(jié)果
cv2.imwrite("map_result.jpg", image_copy)

輸出結(jié)果:

例二

import numpy as np
import cv2
from matplotlib import pyplot as plt

# 讀取圖片
image = cv2.imread("coin.jpg")
image_copy = image.copy()

# 均值遷移濾波
filter = cv2.pyrMeanShiftFiltering(image, 10, 40)

# 轉(zhuǎn)換成灰度圖
filter_gray = cv2.cvtColor(filter, cv2.COLOR_BGR2GRAY)

# 霍夫曼圓圈檢測
circles = cv2.HoughCircles(filter_gray, cv2.HOUGH_GRADIENT, 1, 20, param1=50, param2=100, minRadius=0, maxRadius=0)
circles = np.uint16(np.around(circles))

# 遍歷
for circle in circles[0, :]:
    cv2.circle(image_copy, (circle[0], circle[1]), circle[2], (0, 0, 255), 2)
    cv2.circle(image_copy, (circle[0], circle[1]), 2, (255, 0, 0), 2)

# 圖片展示
f, ax = plt.subplots(2, 2, figsize=(12, 12))

# 子圖
ax[0, 0].imshow(cv2.cvtColor(image, cv2.COLOR_BGR2RGB))
ax[0, 1].imshow(cv2.cvtColor(filter, cv2.COLOR_BGR2RGB))
ax[1, 0].imshow(filter_gray, "gray")
ax[1, 1].imshow(cv2.cvtColor(image_copy, cv2.COLOR_BGR2RGB))

# 標(biāo)題
ax[0, 0].set_title("original")
ax[0, 1].set_title("image filter")
ax[1, 0].set_title("image gray")
ax[1, 1].set_title("image circle")

plt.show()

# 保存結(jié)果
cv2.imwrite("coin_result.jpg", image_copy)

輸出結(jié)果:

到此這篇關(guān)于OpenCV半小時掌握基本操作之圓圈檢測的文章就介紹到這了,更多相關(guān)OpenCV圓圈檢測內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • OpenCV半小時掌握基本操作之圖像裁剪融合
  • OpenCV半小時掌握基本操作之圖像處理
  • opencv-python基本圖像處理詳解
  • OpenCV圖像處理基本操作詳解
  • Opencv圖像處理之詳解掩膜mask
  • 基于python的opencv圖像處理實現(xiàn)對斑馬線的檢測示例
  • Python+OpenCV圖像處理——圖像二值化的實現(xiàn)
  • OpenCV半小時掌握基本操作之分水嶺算法
  • OpenCV半小時掌握基本操作之傅里葉變換
  • OpenCV半小時掌握基本操作之圖像輪廓
  • OpenCV半小時掌握基本操作之直方圖
  • OpenCV半小時掌握基本操作之模板匹配
  • OpenCV半小時掌握基本操作之對象測量
  • OpenCV半小時掌握基本操作之圖像基礎(chǔ)操作

標(biāo)簽:滄州 新疆 樂山 長治 紅河 上海 沈陽 河南

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《OpenCV半小時掌握基本操作之圓圈檢測》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    云安县| 洱源县| 驻马店市| 昭苏县| 辽源市| 措勤县| 新绛县| 沧州市| 讷河市| 增城市| 祁东县| 军事| 屏南县| 吉木乃县| 临清市| 上思县| 新乡市| 藁城市| 科尔| 连江县| 宁津县| 绍兴县| 濮阳市| 平乡县| 靖江市| 灵寿县| 明星| 峡江县| 崇信县| 清流县| 江孜县| 于都县| 池州市| 泾源县| 桃江县| 锡林浩特市| 彝良县| 韩城市| 平山县| 阿巴嘎旗| 甘南县|