基于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和工具,使得开发者能够创建出各种交互式和动态的数据可…

无界微前端项目实战

前言 微前端框架:无界 wujievue 微前端是什么 | 无界主应用:Vue 2 elementui子应用:Vue 3viteelement plus 前提 子应用的资源和接口的请求都在主域名发起,所以会有跨域问题,子应用必须做cors 设置vue3vite 项目跨…

爬取B站评论:Python技术实现详解

引言 在当今信息爆炸的互联网时代,用户生成的内容不断涌现,其中包括了各种各样的评论。而B站作为一个充满活力的视频分享平台,其评论区更是一个充满了各种各样精彩评论的宝藏地。那么,有没有一种简单的方法可以将这些评论收集起来…

大模型日报2024-05-03

大模型日报 2024-05-03 大模型资讯 马克扎克伯格宣布Meta发布Llama 3大型语言模型的重大AI新闻 摘要: Meta公司在周四发布了其Llama 3大型语言模型的首两个版本。该模型是Meta AI的动力核心,马克扎克伯格称其为“未来的...”。这一进展标志着Meta在人工智能领域的进…

深度学习心得

1. KL loss 其经常要与softmax一起使用,就是为了学习one-hot分布 2. 降维 Pooling层的作用是增加模型的鲁棒性,让模型对输入的少量变化不那么敏感。 如果真想通过降维,减少模型训练参数,那应该用PCA降维方法, skl…

Java中new一个对象内存区域如何变化?顺序是什么?

Java中new一个对象内存区域如何变化?顺序是什么? 如果你对Java内存区域了解的话,那么肯定会知道,创建对象如果是第一次的话,首先肯定是要加载对应的Class(要创建对象的类),加载的类信息就是放在…

贪心-耍杂技的牛

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

Django之配置数据库

一,创建项目 二,将项目的setting.py中的 DATABASES {default: {ENGINE: django.db.backends.sqlite3,NAME: BASE_DIR / db.sqlite3,} }替换成如下(以mysql为例) DATABASES {default: {ENGINE: django.db.backends.mysql,NAME: …

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

给你二叉树的根节点 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…

数字化思维的目的与价值,你真的懂吗?

在这个数字时代,数字化思维正逐渐成为企业和个人的能力。那么,数字化思维究竟以什么为中心?为了达成什么目的?又具有怎样的价值呢?让我们一起来揭开这个神秘的面纱。 数字化思维以数据为中心。数据成为了决策的关键依据…

Python系列一之excel的读取

这里我常用的 python 对于 excel 的读取库有两个,一个是 xlsxwriter 用于操作 excel 的写入,一个是 xlrd 用于 excel 文件的读取。 使用的库的版本如下: xlsx1.2.6xlrd1.1.0 xlsxwriter 写入 excel 新建一个 excel import xlsxwriterpat…

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

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

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

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

mysql先行笔记

mysql笔记 数据库:DataBase 简称:DB 按照一定格式存储数据的一些文件的组合 数据库管理系统: DataBaseManagement,简称:DBMS 专门用来管理数据库中的数据,可以对数据库中的数据进行增删改查 常见的数据库管理系统&am…

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)是通用数据绑定的良好选择…

QT, 查看局域网在线主机网卡的出厂商

如题 , 通过QProcess获取到的局域网mac地址,使用QNetworkReply (记得要QT network)可以获取其对应的生产产商(将mac地址传入某专门查询mac地址厂商的网站,并分析其返回值,获得结果,…