基于OpenCv的图像Harris角点检测

⚠申明: 未经许可,禁止以任何形式转载,若要引用,请标注链接地址。 全文共计3077字,阅读大概需要3分钟
🌈更多学习内容, 欢迎👏关注👀【文末】我的个人微信公众号:不懂开发的程序猿
个人网站:https://jerry-jy.co/

❗❗❗知识付费,🈲止白嫖,有需要请后台私信或【文末】个人微信公众号联系我

基于OpenCv的图像Harris角点检测

  • 基于OpenCv的图像Harris角点检测
    • 任务需求
    • 任务目标
      • 1、掌握Harris角点检测的简单步骤
      • 2、掌握基于OpenCv进行Harris角点检测
      • 3、掌握基于亚像素角点检测
    • 任务环境
      • 1、jupyter开发环境
      • 2、OpenCv
      • 3、python3.6
    • 任务实施过程
      • 一、Harris角点检测
        • 1.导入所需要的工具包和图像
        • 2.Harris角点检测
      • 二、亚像素角点检测
      • 三、任务小结
  • 说明

基于OpenCv的图像Harris角点检测

任务需求

角点检测(corner detection)是计算机视觉系统中获得图像特征的一种方法,由于角点检测的实时性和稳定性,所以角点检测广泛应用于运动检测、图像匹配、视频跟踪、三维建模和目标识别等领域。角点作为一种特征点,角点检测也被称为特征点检测。

在这里插入图片描述
在这里插入图片描述

任务目标

1、掌握Harris角点检测的简单步骤

2、掌握基于OpenCv进行Harris角点检测

3、掌握基于亚像素角点检测

任务环境

1、jupyter开发环境

2、OpenCv

3、python3.6

任务实施过程

一、Harris角点检测

Harris角点检测算法是Harris和Stephens于1988年在Moravec算法的基础上提出基于信号的点特征提取方法,其基本思想为:使用一个固定窗口在图像上进行任意方向上的滑动,比较窗口中的像素灰度在窗口滑动前与滑动后的变化程度,如果在任意方向上的滑动都有着较大灰度值的变化,那么我们可以认为该窗口中存在角点。

在这里插入图片描述

Harris角点检测的一般步骤是根据图像窗口平移产生灰度变化得到角点响应函数R,对角点响应函数R进行阈值处理和非最大化抑制,得到选择局部区域算子最大的点作为最终的特征点。

在这里插入图片描述

1.导入所需要的工具包和图像
import cv2 # 导入opencv
import matplotlib.pyplot as plt # 导入绘图模块
import numpy as np # 导入numpy库
from utils import im_show # 导入显示图像函数
# 绘制图像直接展示,不用调用plt.show()
%matplotlib inline 
# 用来正常显示中文标签
plt.rc('font',family="SimHei")
# 读取图像
img = cv2.imread(r'./experiment/data/qp.png')
# 将图像转换成灰度图像
gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
# 设置画布大小
plt.figure(figsize=(6,6))
# 显示图像
im_show('原图像',gray)

在这里插入图片描述

2.Harris角点检测

OpenCV提供函数cv2.cornerHarris()进行Harris角点检测

cv2.cornerHarris(InputArray src,OutputArray dst, int blockSize, int ksize, double k, intborderType=BORDER_DEFAULT )

  • src:源图像且需为单通道8位或者浮点型图像
  • dst:存放Harris角点检测的输出结果,和源图片有一样的尺寸和类型
  • blockSize:邻域大小(角点检测中指定区域的大小为 b l o c k S i z e ∗ b l o c k S i z e blockSize*blockSize blockSizeblockSize
  • ksize:Sobel()算子的模板大小
  • k:角点响应函数R中的k参数,常取0.04~0.06
  • borderType:图像像素的边界模式,默认值为BORDER_DEFAULT
# 1.将灰度图数据转换为浮点数
gray = np.float32(gray)
# 2.使用cornerHarris()进行Harris角点检测
# 放入灰度图,设置窗口大小为2*2,
# sobel算子大小为3*3,k在0.04到0.06之间,取0.05
dst = cv2.cornerHarris(gray,2,3,0.05)
# 3.设置阈值,将角点绘制出来,阈值根据图像进行选择
# 在原图像中设置dst中大于0.01倍的dst的最大值的像素点为红色
img[dst>0.01*dst.max()]=[0,0,255]
# 设置画布大小
plt.figure(figsize=(6,6))
# 显示角点检测后的图像
im_show('Harris角点检测(红色角点)',img)

在这里插入图片描述

二、亚像素角点检测

如果想要找到最精确的角点。可以使用OpenCV函数cv2.cornerSubPix()用来对检测到的角点作进一步的优化计算,可使角点的精度达到亚像素级别。

对于下面的例子来说进行亚像素角点检测需要如下三步:

  • 1.首先找到harris角点,然后找到这些点的质心。
  • 2.harris角点用红色像素标记,精制角用绿色像素标记。
  • 3.定义搜索角点领域的大小和达到一定精度后停止迭代。

cv2.cornerSubPix(InputArray _image, InputOutputArray _corners,Size win, Size zeroZone, TermCriteria criteria)

  • image:输入图像
  • corners:提取的初始整数角点(Harris角点)
  • win:求取亚像素角点的窗口大小,这里设置的是半径长度。
  • zeroZone:设置的“零区域”,在搜索窗口内,设置的“零区域”内的值不会被累加,权重值为0。
  • criteria:条件阈值,包括迭代次数阈值和误差精度阈值,一旦其中一项条件满足设置的阈值,则停止迭代,获得亚像素角点。
# 读取图像
img = cv2.imread(r'./experiment/data/blox.jpg')
# 将图像转换成灰度图
gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
# 将灰度图数据转换为浮点数
gray = np.float32(gray)
# 1.获取Harris角点
dst = cv2.cornerHarris(gray,2,3,0.04)
# 使用阈值函数,设置阈值为0.01*dst.max(),图像灰度值大于0.01*dst.max()的设为255,小于的设为0
ret, dst = cv2.threshold(dst,0.01*dst.max(),255,cv2.THRESH_BINARY)
# 将dst转换成uint8
dst = np.uint8(dst)
# dst得到的就是Harris角点
# 2.寻找这些角点的质心
# connectedComponentsWithStats()函数进行连通域提取
# 放入二值图
ret, labels, stats, centroids = cv2.connectedComponentsWithStats(dst)
# 得到四个返回值,取最后一个返回值centroids表示连通域的中心点也就是质心
# 3.定义停止条件以及精细化角点的标准
# cv2.TERM_CRITERIA_EPS+cv2.TERM_CRITERIA_MAX_ITER表示迭代次数或者精确度满足时停止迭代
# 迭代次数10,精度0.001
criteria = (cv2.TERM_CRITERIA_EPS + cv2.TERM_CRITERIA_MAX_ITER, 100, 0.001)
# 使用cornerSubPix()函数得到亚像素角点,放入灰度图,得到的质心(转换成浮点型)
# 设置窗口大小为11*11,zeroZone表示没有“零区域”,放入条件阈值
corners = cv2.cornerSubPix(gray,np.float32(centroids),(5,5),(-1,-1),criteria)# 对于得到的质心和角点绘制角点水平拼接
res = np.hstack((centroids,corners))
# 将结果转换称为int整型
res = np.int0(res)
img1 = img.copy()
# 设置Harris角点质心为红色,亚像素角点为绿色
img1[res[:,1],res[:,0]]=[0,0,255]
img1[res[:,3],res[:,2]] = [0,255,0]
# 设置画布大小
plt.figure(figsize=(12,12))
im_show('Harris角点质心(红色)和亚像素角点(绿色)',img1)

在这里插入图片描述

上图得到的就是Harris角点质心和亚像素角点,亚像素角点检测可以获取更为精确的角点位置坐标

三、任务小结

本次实验主要完成基于Harris角点检测和亚像素角点检测。注意进行Harris角点检测源图像且需为单通道8位或者浮点型图像。
进行亚像素角点检测前需要先获取到Harris角点检测的角点,并找到这些角点的质心,并且设置条件阈值。

通过本次实验需要掌握以下内容:

  • 1.掌握基于OpenCv进行Harris角点检测
  • 2.掌握基于亚像素角点检测,可以获取更为精确的角点位置坐标

–end–

说明

本实验(项目)/论文若有需要,请后台私信或【文末】个人微信公众号联系我

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

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

相关文章

使用D3.js进行数据可视化

D3.js介绍 D3.js是一个流行的JavaScript数据可视化库,全称为Data-Driven Documents,即数据驱动文档。它以数据为核心,通过数据来驱动文档的展示和操作。D3.js提供了丰富的API和工具,使得开发者能够创建出各种交互式和动态的数据可…

贪心-耍杂技的牛

问题描述 农民约翰的 N头奶牛(编号为 1…N)计划逃跑并加入马戏团,为此它们决定练习表演杂技。 奶牛们不是非常有创意,只提出了一个杂技表演: 叠罗汉,表演时,奶牛们站在彼此的身上,形…

力扣---二叉树的锯齿形层序遍历

给你二叉树的根节点 root ,返回其节点值的 锯齿形层序遍历 。(即先从左往右,再从右往左进行下一层遍历,以此类推,层与层之间交替进行)。 示例 1: 输入:root [3,9,20,null,null,15,…

基于深度学习神经网络的AI图片上色DDcolor系统源码

第一步:DDcolor介绍 DDColor 是最新的 SOTA 图像上色算法,能够对输入的黑白图像生成自然生动的彩色结果,使用 UNet 结构的骨干网络和图像解码器分别实现图像特征提取和特征图上采样,并利用 Transformer 结构的颜色解码器完成基于视…

PDF Shaper Ultimate 免安装中文破姐版 v14.1

软件介绍 PDF Shaper是一套完整的多功能PDF编辑工具,可实现最高的生产力和文档安全性。它允许你分割,合并,水印,署名,优化,转换,加密和解密您的PDF文件,也可插入和移动页&#xff0…

C语言实验-学生信息管理系统

按以下菜单界面编写学生信息管理系统; 1)录入学生信息首先输入学生人数,然后根据学生人数开辟动态数组; 2)学生信息包括学号、姓名、性别、三门课成绩、总分;其中学号、姓名、 性别、三门课成绩是需要从键盘…

初始《stack》《queue》及手搓模拟《stack》《queue》

目录 前言: stack的介绍和使用 stack的介绍: ​编辑stack的使用: ​编辑stack的模拟实现: queue的介绍和使用 queue的介绍: queue的使用: queue的模拟实现: priority_queue的介绍和使用 priority_queue的介绍:…

Hdfs小文件治理策略以及治理经验

小文件是 Hadoop 集群运维中的常见挑战,尤其对于大规模运行的集群来说可谓至关重要。如果处理不好,可能会导致许多并发症。Hadoop集群本质是为了TB,PB规模的数据存储和计算因运而生的。为啥大数据开发都说小文件的治理重要,说HDFS 存储小文件…

08 - 步骤 表输出

简介 表输出(Table Output)步骤是用于将 Kettle 中的数据写入关系型数据库表的步骤。它允许用户将数据流中的数据插入、更新或删除到目标数据库表中。 使用 场景 我要将处理完的数据流中的sysOrgCode 跟 plateNumber 保存记录到mysql 1、拖拽表输出…

Java Jackson-jr 库使用介绍

介绍 Jackson-jr 是一个轻量级的Java JSON 处理库。这个库被设计用来替代 Jackson 的复杂性。对比 Jackson 的复杂 API,Jackson-jr 的启动速度更快,包大小更小。 虽然Jackson databind(如ObjectMapper)是通用数据绑定的良好选择…

初学python记录:力扣1235. 规划兼职工作

题目: 你打算利用空闲时间来做兼职工作赚些零花钱。 这里有 n 份兼职工作,每份工作预计从 startTime[i] 开始到 endTime[i] 结束,报酬为 profit[i]。 给你一份兼职工作表,包含开始时间 startTime,结束时间 endTime …

ROS服务器通信

目录 一、角色 二、流程 注意 三、例子描述 四、srv文件 编译配置文件 vscode配置 五、Server.cpp编写例子 编写CMakeList 六、观察server的效果 七、Client编写例子 编写CMakeList 八、观察Client的结果 九、Client优化(动态输入) 了解argc…

计算机行业AI前沿报告:混合专家模型技术(MoE)

今天分享的是****AI系列深度研究报告:《计算机行业AI前沿报告:混合专家模型技术(MoE)》。(报告出品方:中信建投证券) 精选内容来源公众:见鹿报告 报告共计: 24页 [报告内容摘要如下] **•核心观点&…

ASP.NET 两种开发模式

1》》WebForm 开发模式 1. 服务器端控件 2. 一般处理程序html静态页Ajax 3. 一般处理程序html模板 如下图 2》》MVC 太复杂的系统,会造成Controller 过复杂。 后来就诞生了 MVP、MVVM等模式

AI大模型探索之路-训练篇12:语言模型Transformer库-Datasets组件实践

系列篇章💥 AI大模型探索之路-训练篇1:大语言模型微调基础认知 AI大模型探索之路-训练篇2:大语言模型预训练基础认知 AI大模型探索之路-训练篇3:大语言模型全景解读 AI大模型探索之路-训练篇4:大语言模型训练数据集概…

FlaUI

FlaUI是一个基于微软UIAutomation技术(简称UIA)的.NET库,它主要用于对Windows应用程序(如Win32、WinForms、WPF、Store Apps等)进行自动化UI测试。FlaUI的前身是TestStack.White,由Roemer开发,旨…

Linux平台下muduo网络库源码编译安装与测试,包含boost库的安装与测试!!!!

最近在学习muduo网络库,先来记录一下如何在Linux平台下编译安装以及测试muduo网络库源码。 获取源码 muduo库源码github仓库地址: https://github.com/chenshuo/muduo 在linux系统下,输入 git clone https://github.com/chenshuo/muduo.git…

QT防止自研软件被复制的基本操作(二)

参考一 自研软件为了防止被人任意复制传播,需要设置注册使用模式。基本原理:通过计算机的特异性编号,加上自己的编码,使用加密算法算出一个生成码。 一、计算机的特异性编号 硬盘的编号:最后一块硬盘的编号就行&#…

【简单讲解下npm常用命令】

🌈个人主页: 程序员不想敲代码啊 🏆CSDN优质创作者,CSDN实力新星,CSDN博客专家 👍点赞⭐评论⭐收藏 🤝希望本文对您有所裨益,如有不足之处,欢迎在评论区提出指正,让我们共…

JavaScript 中的 Class 类

🔥 引言 在ECMAScript 2015(ES6)中,class 关键字被引入,为JavaScript带来了一种更接近传统面向对象语言的语法糖。类是创建对象的模板,它们封装了数据(属性)和行为(方法&…