【进阶OpenCV】 (2)--Harris角点检测

文章目录

harris角点检测

Harris角点检测 算法是一种常用的计算机视觉算法,用于检测图像中的角点。该算法通过计算图像中每个像素的局部自相关矩阵,来判断该像素是否为角点

角点指图像中局部区域与周围区域有较大灰度变化的点或像素。

一、基本思想

使用一个固定的小窗口在图像上进行任意方向的滑动,比较滑动前与滑动后两种情况,窗口中的像素灰度变化程度,如果存在任意方向上的滑动都有 着较大灰度变化(sobel算子),那么我们可以认为该窗口中存在角点

二、算法实现

原图:

1. 函数方法

python 复制代码
cornerHarris(img,blockSize,ksize,k[,dst[,borderType]]) --> dst

该方法通过分析图像中每个像素点周围的局部特征来判断该点是否为角点。

参数:

python 复制代码
-- img:输入图像
-- blockSize:角点检测中要考虑的领域大小
-- ksize:Sobel求导中使用的窗口大小
-- k:Harris角点检测方程中的自由参数,取值参数为[0.04,0.06]
-- dst:返回numpy.ndarray对象,大小和src相同,值越大,对应像素点是角的概率越高

2. 检测角点

将图片转化为灰度图,简化图像信息,去除了颜色变化对特征检测的影响,使得算法能够更专注于像素值(即亮度)的变化。检测亮度变化。

python 复制代码
img = cv2.imread("tu.jpg")
img_gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
dst = cv2.cornerHarris(img_gray,4,3,0.04)

3. 标记角点

cornerHarris()函数方法会返回一串数值数据,cornerHarris()函数方法返回的dst中数值并不是每个点的亮度大小,而是每个像素点作为角点的响应值(R值) 。这些R值构成了一个灰度图像,其中灰度图像的坐标会与原图像对应,而R值则反映了该像素点是角点的可能性大小。具体来说,当R值很大时,可以认为这个点是一个角点

其中,min与max参数表示dst中的最大值与最小值。

基于此,我们可以对dst设定一个大小范围,大于某个值怎将它标记为角点:

python 复制代码
# 标记检测到的角点
img[dst > 0.01 * dst.max()] = [0,0,255]
# 这里通过对焦点响应进行阈值处理,标记出检测到的角点
# 0.05 * dst.max()是一个阈值,大于这个值的像素点会被标记为红色
cv2.imshow('img',img)
cv2.waitKey(0)

总结

本篇介绍了:

如何使用Harris角点检测 算法来检测图片的角点。使用一个固定的小窗口在图像上进行滑动,如果存在任意方向上的滑动都有 着较大灰度变化(sobel算子),那么我们可以认为该窗口中存在角点

算法上,通过比较cornerHarris()函数方法中返回值的大小,来确定角点。

相关推荐
华清远见IT开放实验室2 分钟前
AI 算法核心知识清单(深度实战版1)
人工智能·python·深度学习·学习·算法·机器学习·ai
亚远景aspice3 分钟前
亚远景推出国内首款汽车研发合规AI全栈产品 填补和引领行业AI应用
大数据·人工智能
大囚长5 分钟前
大模型知识与逻辑推理能力的关系
人工智能
世优科技虚拟人5 分钟前
重庆合川发布陶行知AI数字人,世优科技提供数字人全栈技术支持
人工智能·科技·数字人·智能交互
云烟成雨TD9 分钟前
Spring AI 1.x 系列【27】Chat Memory API:让 LLM 拥有上下文记忆能力
java·人工智能·spring
kimi-22210 分钟前
如何让大语言模型稳定输出 JSON 的三层防御体系
人工智能·语言模型·json
weixin_1562415757611 分钟前
基于YOLO深度学习的运动品牌检测与识别系统
人工智能·深度学习·yolo·识别·模型、
兴趣使然黄小黄13 分钟前
【AI-agent】Claude code+Minimax 2.7环境搭建
人工智能·ai编程
物联网软硬件开发-轨物科技13 分钟前
【行业动态】AI发展历程通俗速览
人工智能
实在智能RPA14 分钟前
Agent 在招投标场景能解决哪些问题?——2026年招投标数智化转型深度解析
人工智能·ai