OpenCV自学笔记十九:霍夫变换

2023-09-21 20:01:28

目录

1、霍夫直线变换

2、霍夫圆环变换


1、霍夫直线变换

霍夫直线变换(Hough Line Transform)是一种用于在图像中检测直线的技术。它能够从图像中提取出直线的参数,例如直线的斜率和截距。

霍夫直线变换的基本原理是在参数空间中累加直线的交点。对于每个图像中的边缘点,它们代表了可能的直线候选。通过对这些候选直线进行计数,可以找到在参数空间中累积计数最高的直线,从而得到图像中的直线。

示例:

下面是一个使用OpenCV实现霍夫直线变换的简单示例代码:

import cv2

import numpy as np

# 读取图像并转换为灰度图像

img = cv2.imread('image.jpg')

gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)

# 进行边缘检测

edges = cv2.Canny(gray, 50, 150, apertureSize=3)

# 进行霍夫直线变换

lines = cv2.HoughLines(edges, 1, np.pi/180, threshold=100)

# 绘制检测到的直线

for line in lines:

rho, theta = line[0]

a = np.cos(theta)

b = np.sin(theta)

x0 = a * rho

y0 = b * rho

x1 = int(x0 + 1000*(-b))

y1 = int(y0 + 1000*(a))

x2 = int(x0 - 1000*(-b))

y2 = int(y0 - 1000*(a))

cv2.line(img, (x1, y1), (x2, y2), (0, 0, 255), 2)

# 显示结果

cv2.imshow('Image', img)

cv2.waitKey(0)

cv2.destroyAllWindows()

在上述示例中,我们首先使用`cv2.imread()`函数读取图像,并将其转换为灰度图像。

然后,我们使用`cv2.Canny()`函数进行边缘检测,以提取图像中的边缘。

接下来,使用`cv2.HoughLines()`函数进行霍夫直线变换。该函数接受四个参数:边缘图像、距离分辨率、角度分辨率和阈值。在本例中,我们设置了距离分辨率为1像素、角度分辨率为1度,并将阈值设置为100。

然后,对于每条检测到的直线,在图像上绘制直线。我们使用直线的极坐标表示(rho和theta),将其转换为直线的两个端点坐标,并使用`cv2.line()`函数绘制直线。

最后,使用`cv2.imshow()`函数显示结果图像,并使用`cv2.waitKey()`和`cv2.destroyAllWindows()`等函数等待用户按键关闭窗口。

运行上述代码,你将看到显示了检测到的直线的图像窗口。直线以红色显示在原始图像上。

2、霍夫圆环变换

霍夫圆环变换(Hough Circle Transform)是一种用于在图像中检测圆的技术。它能够从图像中提取出圆的参数,例如圆心坐标和半径。

原理:

霍夫圆环变换的基本原理是在参数空间中累加圆的交点。对于每个图像中的边缘点,它们代表了可能的圆候选。通过对这些候选圆进行计数,可以找到在参数空间中累积计数最高的圆,从而得到图像中的圆。

示例:

下面是一个使用OpenCV实现霍夫圆环变换的简单示例代码:

​
import cv2

import numpy as np

# 读取图像并转换为灰度图像

img = cv2.imread('image.jpg')

gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)

# 进行图像平滑处理

gray = cv2.medianBlur(gray, 5)

# 检测圆环

circles = cv2.HoughCircles(gray, cv2.HOUGH_GRADIENT, dp=1, minDist=50,

param1=100, param2=30, minRadius=0, maxRadius=0)

# 绘制检测到的圆环

if circles is not None:

circles = np.uint16(np.around(circles))

for circle in circles[0, :]:

center = (circle[0], circle[1])

radius = circle[2]

cv2.circle(img, center, radius, (0, 255, 0), 2)

# 显示结果

cv2.imshow('Image', img)

cv2.waitKey(0)

cv2.destroyAllWindows()

​

在上述示例中,我们首先使用`cv2.imread()`函数读取图像,并将其转换为灰度图像。

然后,我们使用`cv2.medianBlur()`函数对灰度图像进行平滑处理,以减少噪声对霍夫圆环变换的影响。

接下来,使用`cv2.HoughCircles()`函数进行霍夫圆环变换。该函数接受七个参数:输入图像、霍夫圆环检测方法、dp值、最小间距、边缘阈值、圆心累加器阈值和最小/最大半径。在本例中,我们设置了霍夫圆环检测方法为`cv2.HOUGH_GRADIENT`,dp值为1,最小间距为50,边缘阈值为100,圆心累加器阈值为30,最小/最大半径为0(表示不限制半径的范围)。

然后,对于检测到的每个圆环,在图像上绘制圆。我们使用圆的圆心坐标和半径,使用`cv2.circle()`函数绘制圆。

最后,使用`cv2.imshow()`函数显示结果图像,并使用`cv2.waitKey()`和`cv2.destroyAllWindows()`等函数等待用户按键关闭窗口。

运行上述代码,你将看到显示了检测到的圆环的图像窗口。圆环以绿色显示在原始图像上。

更多推荐

用Vite从零到一创建React+ts项目

方式一:使用create-react-app命令创建项目1、使用以下命令初始化一个空的npm项目npminit-y2、输入以下命令安装Reactnpmicreate-react-appps:如果失败的话尝试(1:使用管理员身份执行命令(2:切换镜像重试3、输入以下命令创建项目create-react-app项目文件夹名

flask 插件 Flask-RESTful

1、安装pipinstallflask-restful2、使用HelloWorld一个简单的例子:#-*-coding:utf-8-*-fromflaskimportFlaskfromflask_restfulimportResource,Apiapp=Flask(__name__)api=Api(app)classH

解决react使用redux toolkits时出现的数组对象长度始终为0的怪异问题

有个react项目在添加购物车后,立马白屏,看一下console报错propertiesofundefined(readinglength)那意思是说数组没有长度,然后定位Header.tsx的182行,果然是数组长度报错回到具体代码中:发现shoppingCartItems实际是通过reduxToolkit(RTK)

大模型从入门到应用——LangChain:代理(Agents)-[工具(Tools):人工确认工具验证和Tools作为OpenAI函数]

分类目录:《大模型从入门到应用》总目录LangChain系列文章:基础知识快速入门安装与环境配置链(Chains)、代理(Agent:)和记忆(Memory)快速开发聊天模型模型(Models)基础知识大型语言模型(LLMs)基础知识LLM的异步API、自定义LLM包装器、虚假LLM和人类输入LLM(HumanInpu

Pytorch-YOLOv4梳理——原理和复现

yolov1到yolov3的梳理:YOLO总结,从YOLOv1到YOLOv3_追忆苔上雪的博客-CSDN博客首先说一点,就是yolov4的分支有点多,先梳理一下出现的顺序。AlexeyBochkovskiy提出了YOLOv4然后针对YOLOv4的模型缩放(modelscale),提出了Scaled-YOLOv4Scal

黑马JVM总结(八)

(1)StringTable面试题1.81.6时(2)StringTable的位置jvm1.6时StringTable是常量池的一部分,它随着常量池存储在永久代当中,在1.7、1.8中从永久代变成了堆中,为什么做这个更改呢?因为永久代的内存效率很低,永久代是在FullGC的时候才会触发永久代的垃圾回收,FullGC只有

Archicad 26 for Mac - 打造卓越的3D建模工具

随着建筑设计和规划的日益复杂化,寻找一款功能强大且易于使用的3D建模工具变得至关重要。而Archicad26forMac正是您在建筑设计领域中的理想选择。无论您是一名建筑师、室内设计师还是建筑工程师,Archicad26都将成为您的得力助手。作为一款全球领先的BIM(建筑信息模型)软件,Archicad26forMac

Spring 6.0 新特性

文章目录Spring的发展历史AOTGraalVMSpringBoot实战AOTRuntimeHints案例分析RuntimeHintsRegistrarSpringBoot中AOT核心代码Spring的发展历史AOTSpring6.0的新特性AheadofTime(AOT)编译是一种技术,可以提前将Spring应用程

Jmeter常用线程组设置策略

一、前言​在JMeter压力测试中,我们时常见到的几个场景有:单场景基准测试、单场景并发测试、单场景容量测试、混合场景容量测试、混合场景并发测试以及混合场景稳定性测试在本篇文章中,我们会用到一些插件,在这边先给大家列出:​CustomThreadGroups插件PS:在我们正式测试中,统一使用非GUI界面运行,只有在调

对比接口测试工具在自动化测试优缺点:Jmeter、Python、Postman

一、JMeter总结:适合对代码不敏感的使用人员,不会代码也可以完成接口自动化,设计框架。适合紧急迭代的项目。JMeter接口测试的优势小巧轻量级,并且开源免费,社区接受度高,比较容易入门支持多协议,并提供了比较高级的扩展能力,允许自己定义和扩展新的协议支持,比如扩展支持阿里提供的Dubbo协议的JMeter插件等学习

JMeter 常见函数讲解

当使用JMeter进行性能测试或负载测试时,函数是一个非常有用的工具,可以帮助生成动态的测试数据或处理测试结果。下面是一些常用的JMeter函数的详细讲解和并列示例:1、__threadNum:返回当前线程的编号。可以在测试过程中用于生成唯一的标识符或动态数据。生成唯一的用户名:${__threadNum}-user动

热文推荐