OpenCV学习记录——边缘检测

文章目录


前言

在做某些图像处理时,通常需要将识别到的物体边界提取 出来,从而帮助我们实现目标检测,这就需要用到边缘检测,例如人脸识别和运动目标的检测都需要先进行边缘检测,这篇文章就记录一下边缘检测的原理及应用代码。

一、边缘检测原理

边缘检测是图像处理和计算机视觉中的基本问题 ,其目的在于标识数字图像中亮度变化明显 的点,图像边缘检测大幅度地减少了数据量 ,并且剔除 了可看作不相关的信息保留 了图像重要的结构属性。边缘的表现形式如下图所示:

常用的Canny边缘检测算法实际上是通过寻找图像一阶导数 中的最大值和最小值 来检测边界,通常是将边界定位在梯度最大的方向。

二、Canny边缘检测算法

Canny 边缘检测算法 是一种非常流行的边缘检测算法,是 John F.Canny 于 1986 年提出的,被认为是最优的边缘检测算法。它可分为4个步骤:去除噪声、计算图像梯度、非极大值抑制和滞后阈值。

(一)去除噪声

边缘检测极易 受到噪声影响,因此需要使用高斯滤波器去除噪声,具体方法可以查看本专栏的前一篇文章,下图是去除噪声和没去除噪声的边缘检测对比:

显然第三张未去除噪声的边缘检测不够清晰,非常混乱,不方便进行识别

(二)计算图像梯度幅值与方向

图像中用梯度表示灰度值变化程度与方向 ,而边缘 就是指灰度强度变化最强的位置。 梯度方向与边缘方向呈垂直关系,具体的计算方法在这里就不做记录了。

(三)非极大值抑制

非极大值抑制,即保留局部最大值,抑制非局部最大值的所有值。简单而言,就是对图像的所有像素点进行检测,如果某点的梯度强度大于其梯度方向的正负方向的像素点,则该点保留;否则,该点被抑制。Canny 边缘检测算法是沿着梯度方向对幅值进行非极大值抑制的,而非边缘方向。

(四)滞后阈值

为了确定真正的边界,需要设定两个阈值 "minVal""maxVal"。 当图像某点的灰度梯度大于阈值 "maxVal" ,该点被视为真的边界点;当某点的灰度梯度小于阈值"minVal",则该点不看作边界点;当某点的灰度梯度介于两个阈值之间,根据该点是否与真的边界点相连来进行判断,相 连则将该点也看作边界点,否则将其抛弃。

Canny边缘检测函数如下:

python 复制代码
cv2.Canny(image, threshold1, threshold2)

其中的三个参数分别为:

(1)"image", 进行边缘检测的图像

(2)"threshold1",低阈值 "minVal"

(3)"threshold2",高阈值 "maxVal"

三、具体应用代码

进行Canny边缘检测的具体应用代码如下:

python 复制代码
import cv2

# 图像读取
img = cv2.imread('KAI.jpg')

# Canny边缘检测
minVal = 1       # 设置低阈值
maxVal = 80      # 设置高阈值
blur = cv2.GaussianBlur(img, (5, 5), 1)    # 进行高斯滤波
canny = cv2.Canny(blur, minVal, maxVal)    # 进行边缘检测

# 图像展示
cv2.imshow('edge', canny)
cv2.waitKey(0)
cv2.destroyAllWindows()

代码效果如下:

相关推荐
山东小木1 分钟前
AI应用开发:节点化思维链与Skills经验库如何重塑企业级AI智能体
大数据·人工智能·skills·java ai·springboot ai
爱笑的眼睛114 分钟前
深度解析现代OCR系统:从算法原理到高可用工程实践
java·人工智能·python·ai
敢敢のwings4 分钟前
从Spatial-MLLM看到Multi-SpatialMLLM的多模态大语言模型
人工智能·语言模型·自然语言处理
deng-c-f4 分钟前
Linux C/C++ 学习日记(55):原子操作(四):实现无锁队列
学习
WangLanguager6 分钟前
HMM在金融时间序列分析中有什么作用?
人工智能·机器学习·金融
北山小恐龙10 分钟前
针对性模型压缩:YOLOv8n安全帽检测模型剪枝方案
人工智能·深度学习·算法·计算机视觉·剪枝
IT_陈寒10 分钟前
JavaScript性能优化:7个V8引擎内部原理帮你减少90%内存泄漏的实战技巧
前端·人工智能·后端
小韩博12 分钟前
小迪安全 · 第 39 课学习笔记
笔记·学习·安全·网络安全
非凡ghost13 分钟前
Topaz Video(人工智能视频增强软件)
人工智能·windows·学习·音视频·软件需求
余俊晖13 分钟前
从豆包手机等看GUI Agent:MobileRL GUI Agent训练框架和安卓XML预处理
人工智能·语言模型·自然语言处理·gui