opencv进阶14-Harris角点检测-cv2.cornerHarris

news2024/11/17 5:30:19

类似于人的眼睛和大脑,OpenCV可以检测图像的主要特征并将这 些特征提取到所谓的图像描述符中。然后,可以将这些特征作为数据
库,支持基于图像的搜索。此外,我们可以使用关键点将图像拼接起 来,组成更大的图像。(想象一下把很多图片放到一起组成一幅360°的全景图。)

本节将展示如何使用OpenCV检测图像中的特征,并利用这些特征
匹配和检索图像。在本节的学习过程中,我们会获取样本图像并检测
其主要特征,然后试着在另一幅图像中找到与样本图像匹配的区域。
我们还将找到样本图像和另一幅图像匹配区域之间的单应性或者空间
关系。

Harris角点检测是计算机视觉领域中一种经典的角点检测算法,它可以用于许多应用场景。

以下是一些Harris角点检测的应用场景

图像配准: 在图像配准中,Harris角点检测可以用于找到两幅图像中具有相似特征的角点,从而进行图像对齐和匹配。

物体跟踪: 在目标跟踪中,Harris角点检测可以用于提取图像中的显著特征,帮助识别和跟踪目标。

摄像头标定: 在摄像头标定中,Harris角点检测可以用于检测摄像头拍摄图像中的角点,帮助计算摄像头的内参和外参。

三维重建: 在三维重建中,Harris角点检测可以用于提取图像中的关键特征点,帮助建立图像间的对应关系,从而实现场景的三维重建。

物体识别: 在物体识别中,Harris角点检测可以用于提取图像中的特征点,帮助识别和分类不同的物体。

自动驾驶: 在自动驾驶领域,Harris角点检测可以用于检测图像中的道路边缘和关键特征,帮助自动驾驶系统判断道路情况。

图像拼接: 在图像拼接中,Harris角点检测可以用于提取图像中的角点,帮助找到不同图像之间的对应关系,实现图像拼接和全景图生成。

图像匹配: 在图像匹配中,Harris角点检测可以用于寻找两幅图像中具有相似特征的角点,从而进行图像配准和匹配。

理解特征检测和匹配的类型

OpenCV中最常用的特征检测和描述符提取算法如下:

  • Harris:该算法适用于角点检测。
  • SIFT:该算法适用于斑点检测。
  • SURF:该算法适用于斑点检测。
  • FAST:该算法适用于角点检测。
  • BRIEF:该算法适用于斑点检测。
  • ORB:它是Oriented FAST和Rotated BRIEF的联合缩写。ORB对于角点和斑点的组合检测很有用。

可以通过下列方法进行特征匹配:

  • 蛮力匹配。
  • 基于FLANN的匹配。

可以通过单应性进行空间验证。

究竟什么是特征?

为什么图像的某个特定区域可以归类为特征,而其他区域则不能分类为特征呢?广义地说,特征是图像中独特或容易识别的一个感兴趣区域。具有高密度纹理细节的角点和区域是好的特征,而在低密度区域(如蓝天)不断重复出现的模式就不是好的特征。边缘是好的特征,因为它们倾向于把图像分割成两个区域。斑点(与周围区域有很大差别的图像区域)也是一个有趣的特征。

大多数特征检测算法都围绕着角点、边缘和斑点的识别展开,有
些还关注岭(ridge)的概念,其中岭可以概念化为细长物体的对称
轴。(例如,想象一下识别图像中的道路。)

有些算法更擅长识别和提取特定类型的特征,所以了解输入图像
是什么很重要
,这样就可以利用OpenCV中的最佳工具了。

检测Harris角点

什么是角点?

在计算机视觉和图像处理中,角点(Corner)是图像中突出的、有角度的、明显的像素点。角点通常位于图像中物体的边缘、纹理或其他特征的交叉点,是图像中的显著特征点。角点对于图像处理中的许多任务,如特征匹配、目标跟踪、3D重建等,具有重要的作用。

角点具有以下特征:

局部极大值: 在角点周围的邻域中,角点的像素值应该是局部最大值。

方向变化: 角点处的像素点方向会在不同方向上有较大的变化,这是因为角点是明显的图像特征。

明暗对比: 角点处的像素点周围可能是明暗对比较大的区域,因为角点是由物体的边缘、纹理等特征交叉形成的。

可重复性: 角点在不同的尺度和旋转下仍然可以被检测到,这使得它们在不同场景中都有用途。

下面看一下角点的类型:
在这里插入图片描述

cv2.cornerHarris 函数说明

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

公式中参数:

  • img表示原始图像
  • blockSize表示角点检测中的领域大小
  • ksize表示Sobel求导中使用的窗口大小
  • k表示Harris 角点检测方程中的自由参数,取值参数为[0,04, 0.06]

代码示例:

import numpy as np
import cv2

# 读取待检测的图像
img = cv2.imread('chess_board.png')
# 转换为灰度图像
gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
gray = np.float32(gray)
# 调用函数 cornerHarris,检测角点,其中参数 2 表示 Sobel 算子的孔径大小,23 表示 Sobel 算子的孔径大小,0.04 表示 Harris 角点检测方程中的 k 值
dst = cv2.cornerHarris(gray,2,23,0.04)

dst = cv2.dilate(dst,None)
# 将检测到的角点标记出来
img[dst>0.01*dst.max()]=[0,0,255]

cv2.imshow('dst',img)

cv2.waitKey(0)
cv2.destroyAllWindows()

运行效果:

在这里插入图片描述
这里,我们选取的像素的分值至少是最高分值的1%,并在原始图
像中将这些像素涂成红色。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/906674.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

云上社群系统部分接口设计详解与测试

目录 一、项目简介 1. 使用统一返回格式+全局错误信息定义处理前后端交互时的返回结果 2.使用ControllerAdviceExceptionHandler实现全局异常处理 3.使用拦截器实现用户登录校验 4. 使用MybatisGeneratorConfig生成常的增删改查方法 5. …

SVF——C/C++指针分析/(数据)依赖分析框架

这篇文章包括: SVF介绍SVF源码解读SVF优势与不足如何扩展改进 文章包括一些个人观点,若觉得有误请留言纠正,感谢🙏 在这篇文章之前强烈推荐看我公众号之前推的一篇文章:CG0’2011 “Flow-sensitive pointer analysis f…

追踪工时和控制成本 如何选对工具

研发工作中的工时管理软件是一种用于追踪、记录和分析团队成员在项目中所花费的工作时间的工具。它有助于组织、监控和优化研发项目的进展,确保资源得到有效利用,项目按时完成,并提供数据支持用于决策制定和资源规划。 能够记录团队成员的工…

高忆管理:“降息”了!1年期下调10个基点,5年期为何“按兵不动”?有何影响?

1年期LPR利率年内再度下调,5年期以上LPR利率按兵不动。 8月21日,新一期借款商场报价利率(LPR)公布。其间,1年期借款商场报价利率(LPR)报3.45%,上月为3.55%;5年期以上LPR报…

5种做法实现table表格中的斜线表头效果(HTML+CSS+JS+Canvas+SVG)

table表格,这个东西大家肯定都不陌生,代码中我们时常都能碰到,那么给table加一个斜线的表头有时是很有必要的,但是到底该怎么实现这种效果呢? 我总结了以下几种方法: 1、最最最简单的做法 直接去找公司的…

电脑图纸怎么加密?图纸加密软件有哪些?

对于企业来说,图纸的重要性是不言而喻的,为了避免图纸泄露,我们需要将图纸加密保护。那么电脑图纸该怎么加密呢?下面我们就来看一下。 图纸加密会带来哪些好处? 保护企业利益 为图纸加密可以有效地保护知识产权&…

Openlayers 教程 - 以单位米为半径,绘制圆形图形要素

Openlayers 教程 - 以单位米为半径,绘制圆形图形要素 核心代码完整代码:在线示例 在以往的项目维护中,出现一个问题,使用最新高清底图发现,设置地图最大等级(21级)之后,地图虽然可以…

Steam搬砖项目:最长久稳定的副业!

项目应该大家都有听说话,但是细节问题,如何操作可能有些不是很清楚,今天在这里简单分享一下。 这个Steam搬砖项目主要赚钱汇率差和价值差,是一个细分领取的小项目。 不用引流,时间也是比较自由的,你可以兼…

vue 可拖拽可缩放 vue-draggable-resizable 组件常用总结

特征 没有依赖 使用可拖动,可调整大小或两者兼备定义用于调整大小的句柄限制大小和移动到父元素或自定义选择器将元素捕捉到自定义网格将拖动限制为垂直或水平轴保持纵横比启用触控功能使用自己的样式为句柄提供自己的样式 安装和基本用法 npm install --save vue-d…

【BASH】回顾与知识点梳理(三十七)

【BASH】回顾与知识点梳理 三十七 三十七. 基础系统设定与备份策略37.1 系统基本设定网络设定 (手动设定与 DHCP 自动取得)手动设定 IP 网络参数(nmcli)自动取得 IP 参数(dhcp)修改主机名(hostnamectl) 37.2 日期与时间设定时区的显示与设定时间的调整用 ntpdate 手动网络校时 …

Istio入门体验系列——基于Istio的灰度发布实践

导言:灰度发布是指在项目迭代的过程中用平滑过渡的方式进行发布。灰度发布可以保证整体系统的稳定性,在初始发布的时候就可以发现、调整问题,以保证其影响度。作为Istio体验系列的第一站,本文基于Istio的流量治理机制,…

MyBatis的基本入门及Idea搭建MyBatis坏境且如何实现简单的增删改查(CRUD)---详细介绍

一,MaBatis是什么? 首先是一个开源的Java持久化框架,它可以帮助开发人员简化数据库访问的过程并提供了一种将SQL语句与Java代码进行解耦的方式,使得开发人员可以更加灵活地进行数据库操作。 1.1 Mabatis 受欢迎的点 MyBatis不仅是…

玄而又玄——我亲历的三大总线

总线是计算机系统中的桥梁和公路。对于要学习计算机系统的人来说,如果不理解总线,那么很多认知就没办法落到实处,想不清两样东西是如何连接起来,数据是如何从一点到另一点的。 最近两三年,做了比较多的底层开发&#x…

Scratch 之 创作小技巧 -- 让触碰效果更丝滑

今天小技巧的主题是——丝滑 a.让触碰效果更丝滑 ——非线性放大 相信大家,做游戏时都会有一开始按键吧,把鼠标放上去,这个按键就会有相应的变化,如放大,作为初学者,这段的代码可能是这样↓ 虽然看起来挺…

解析大规模开发:提升企业级开发效率与质量,加速创新

在数字化转型的大环境下,越来越多的企业依赖软件来驱动业务和创新。然而,随着开发规模日益庞大,如何更好地提升研发效能,从而塑造更强大的竞争力,已然成为众多企业亟待解决的共同难题。 作为国内领先的DevSecOps提供商…

凉而不冷 柔而不弱 三菱重工海尔舒适风科技助您整夜安眠

古人云:安寝乃人生乐事。可随着夏天的到来,昼长夜短,家里的老人、儿童、父母都存在不同的入睡苦恼。对于儿童来说,空调温度调的太低容易踢被子着凉,温度调的高又怕孩子满头大汗;父母自身也会因为半夜帮孩子…

盛元广通高校实验室开放预约与综合管理系统LIMS

系统概述: 高校实验室涉及到的课程、老师、学生多,管理起来费时费力,盛元广通高校实验室开放预约与综合管理系统LIMS提供简单易用的账号管理、实验室管理、课程管理、实验项目管理、实验时间设定;为学生提供简单易用的自主实验选…

使用 NBAR(基于网络的应用程序识别) 进行应用流量分析

识别和分类网络应用程序是有效管理网络带宽的关键。通过对网络流量进行分类,管理员可以根据企业的需要可视化、组织和确定网络流量的优先级。通过识别和分类网络流量,网络管理员可以有效地应用 QoS 策略,从而实现优化的网络带宽性能。 什么是…

docker 安装oracle19c linux命令执行sql

docker安装oracle # 下载镜像 19.3.0.0.0 docker pull registry.cn-hangzhou.aliyuncs.com/laowu/oracle:19c # 创建文件 mkdir -p /home/mymount/oracle19c/oradata # 授权,不授权会导致后面安装失败 chmod 777 /home/mymount/oracle19c/oradatadocker run -d \ …

0基础学习VR全景平台篇 第88篇:智慧眼-成员管理

一、功能说明 成员管理,是指管理智慧眼项目的成员,拥有相关权限的人可以进行添加成员、分配成员角色、设置成员分类、修改成员以及删除成员五项操作。但是仅限于管理自己的下级成员,上级成员无权管理。 二、前台操作页面 登录智慧眼后台操…