news 2026/4/15 18:23:15

cv2.cornerHarris() 详解(Harris 角点检测)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
cv2.cornerHarris() 详解(Harris 角点检测)

cv2.cornerHarris() 详解(Harris 角点检测)

cv2.cornerHarris() 是 OpenCV 中实现Harris 角点检测的核心函数,用于检测图像中的角点(角点定义:图像中在两个正交方向上灰度变化都很大的像素点,如物体边缘的交点)。以下是完整的使用指南、参数解析、实战示例和避坑技巧:

一、核心原理

Harris 角点检测通过计算像素点的自相关矩阵,分析该点邻域内的灰度变化:
若两个方向的灰度变化都大 → 角点;
仅一个方向变化大 → 边缘;
无明显变化 → 平坦区域。最终通过响应值(R)判断是否为角点:R > 阈值 则判定为角点。

二、函数语法与参数

dst = cv2.cornerHarris(src, blockSize, ksize, k)

完整使用步骤

# -*- coding:utf-8 -*-importcv2 as cvimportnumpy as npimportsysif__name__=='__main__':# 读取图像image=cv.imread('./images/test.jpg')ifimage is None: print('Failed to read test.jpg.')sys.exit()# 转为灰度图像gray=cv.cvtColor(image, cv.COLOR_BGR2GRAY)# 计算Harris系数harris=cv.cornerHarris(gray,2,3,0.04,borderType=cv.BORDER_DEFAULT)# 对Harris进行归一化便于进行数值比较harris_nor=cv.normalize(harris, None,alpha=0,beta=255,norm_type=cv.NORM_MINMAX)harris_nor=harris_nor.astype('uint8')# 寻找Harris角点kps=[]foriinnp.argwhere(harris_nor>125): kps.append(cv.KeyPoint(i[1], i[0],1))# 绘制角点result=cv.drawKeypoints(image, kps, None)# 展示结果cv.imshow('R', harris_nor)cv.imshow('Harris KeyPoints', result)cv.waitKey(0)cv.destroyAllWindows()

常见错误及解决

错误 1:输入图像类型错误

plaintext
error: (-215:Assertion failed) src.type() == CV_32F || src.type() == CV_8U
原因:输入图像不是单通道灰度图,或未转为浮点型;
解决:确保 src 是灰度图,且执行 gray = np.float32(gray)。

错误 2:角点标记无效果

原因:阈值过高,或 k 取值不合理;
解决:降低阈值(如 0.01dst.max() → 0.005dst.max()),调整 k 至 0.04~0.06。

错误 3:亚像素检测报错

plaintext
error: (-215:Assertion failed) src.size() == patternSize
原因:corners 格式错误(需是 (N,2) 的浮点数组);
解决:确保 corners = np.float32(corners[:, ::-1]) 转换坐标格式。

适用场景与局限性

总结

cv2.cornerHarris() 核心是调参 blockSize、ksize、k,需根据图像分辨率 / 噪声调整;
降噪(高斯模糊)是提升检测效果的关键前置步骤;
高精度场景需结合 cv2.cornerSubPix() 实现亚像素级检测;
对比 Shi-Tomasi 角点检测,Harris 更适合粗检测,Shi-Tomasi 速度更快、结果更稳定。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/10 12:09:23

v-scale-screen与Element Resize检测联动:深入解析

如何让大屏页面在任何设备上完美还原?揭秘v-scale-screen与 ResizeObserver 的黄金组合你有没有遇到过这样的场景?设计师甩来一张19201080的精致大屏设计稿,信誓旦旦地说:“就按这个做,别变形。”结果上线后&#xff0…

作者头像 李华
网站建设 2026/4/10 20:49:07

快速入门:单精度浮点数转换的三大要点

深入理解单精度浮点数转换:从底层原理到工程实践你有没有遇到过这样的问题?在嵌入式系统中,明明写的是0.1f 0.2f,结果却不等于0.3f;音频处理时滤波效果不理想,排查半天才发现是浮点系数没对齐;…

作者头像 李华
网站建设 2026/4/7 12:31:00

LangFlow LogRocket会话重放调试工具

LangFlow 与会话重放:构建可追溯的 AI 工作流调试体系 在智能应用开发日益依赖大语言模型(LLM)的今天,一个核心矛盾正变得愈发突出:我们拥有了越来越强大的生成能力,却对这些系统的运行过程失去了掌控。当一…

作者头像 李华
网站建设 2026/4/14 9:20:03

远程监控系统中蜂鸣器报警机制:系统学习版

蜂鸣器如何成为远程监控系统的“最后防线”?一位嵌入式工程师的实战解析最近在调试一个工业级远程监控网关时,客户反复强调一句话:“就算断网、断电,报警也得响起来!”这让我重新审视了系统中那个不起眼的小部件——蜂…

作者头像 李华
网站建设 2026/4/7 1:39:26

LangFlow Naemon高性能监控引擎

LangFlow Naemon高性能监控引擎技术解析 在AI应用开发日益普及的今天,一个看似简单的问题却频繁困扰着开发者:如何快速构建一个复杂的LangChain工作流,并确保它在部署后稳定运行?传统的做法是手写大量Python代码,逐行调…

作者头像 李华
网站建设 2026/4/15 3:58:38

LangFlow Pingdom网站可用性监控

LangFlow 与 Pingdom:构建可信赖的 AI 应用可观测体系 在生成式 AI 技术迅猛发展的今天,越来越多团队开始尝试使用大语言模型(LLM)快速搭建智能应用原型。然而,一个常被忽视的问题是:我们花了很多精力去“造…

作者头像 李华