OpenCV图像特征提取学习二,Shi-Tomasi 角点检测算法

2023-12-12 04:50

本文主要是介绍OpenCV图像特征提取学习二,Shi-Tomasi 角点检测算法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一.Shi-Tomasi 角点检测算法

Harris角点检测基本数学公式如下: 

                            E\left ( u,v \right ) = \sum_{x,y}^{}w\left ( x,y \right )\left [ I\left ( x+u,y+v \right )-I\left ( x,y \right ) \right ]^{2}

泰勒公式进行展开后,近似为:

                            E \approx \left [ u,v \right ]\sum w\left ( u,v \right )\left [ \binom{I_{x}^{2},I_{x}I_{y}}{I_{x}I_{y},I_{y}^{2}} \right ]\binom{u}{v}

对于局部微小的移动量\left [ u,v \right ],可以近似得到下面的表达:

                             E \approx \left [ u,v \right ]M\begin{bmatrix} u\\ v\end{bmatrix}

其中M为2*2的矩阵,可由图像的导数求得:

                             M = \sum_{x,y}^{}w\left ( u,v \right )\begin{bmatrix} I_{x}^{2}&I_{x}I_{y}\\ I_{x}I_{y}&I_{y}^{2}\end{bmatrix}

矩阵M,将其对角化之后 ,特征值λ1, λ2 分别代表了X 和Y 方向的灰度变化率.

                             M = \sum_{x,y}^{}w\left ( u,v \right )\begin{bmatrix} I_{x}^{2}&I_{x}I_{y}\\ I_{x}I_{y}&I_{y}^{2}\end{bmatrix} = \begin{bmatrix} \lambda _{1}&0\\ 0&\lambda _{2}\end{bmatrix}

E\left ( u,v \right )的椭圆形式如下:

                              

Harris角点检测算法的角点响应函数为:

                                 R = \lambda _{1}\lambda _{2}-K\left ( \lambda _{1}+\lambda _{2} \right )^{2}

Harris角点检测算法就是对角点响应函数R进行阈值处理:R > threshold,即提取R的局部极大值。shi-Tomasi 算法是基于Harris 算法进行的改进,Harris算法最基础的数学定义是将矩阵 M 的行列式值与矩阵 M 的迹相减,再将差值与预先给定的阈值进行比较。若两个特征值中较小的一个大于最小阈值,则会得到强角点,这就是Shi-Tomasi角点检测算法。

Shi-Tomasi角点检测算法的角点响应函数为:

                                 R =min \left ( \lambda _{1},\lambda _{2} \right )

Shi-tomasi角点检测 和Harris 算法一样,如果该分数大于设定的阈值,我们就认为它是一个角点。可以看出来只有当 λ1 和 λ 2 都大于最小值时,才被认为是角点,即下图中的紫色区域。

--------------------------------------------------------------------------------------------------------------------------------

二.Shi-Tomasi角点检测API函数接口

void goodFeaturesToTrack
(            InputArray image, OutputArray corners,int maxCorners, double qualityLevel, double minDistance,InputArray mask=noArray(), int blockSize=3,bool useHarrisDetector=false, double k=0.04 );

参数说明:

第一个参数image:输入图像,8位或浮点32比特,单通道图像;
第二个参数corners:输出参数,检测到的角点;表示返回角点的数目,如果检测出来角点数目大于最大数目则返回响应值最强前规定数目;
第三个参数corner_count:输出参数,检测到的角点数目;
第四个参数quality_level:最大最小特征值的乘法因子。定义可接受图像角点的最小质量因子;
第五个参数min_distance:限制因子。得到的角点的最小距离;使用 Euclidian 距离;
第六个参数mask:ROI感兴趣区域。函数在ROI中计算角点;如果 mask 为 NULL,则选择整个图像;
第七个参数block_size: 是计算导数的自相关矩阵时指定点的领域,采用小窗口计算的结果比单点 (也就是block_size为1)计算的结果要好;
第八个参数useHarrisDetector:当use_harris的值为非0,则函数使用Harris的角点定义;若为 0,则使用Shi-Tomasi的定义;
第九个参数K:用于设置Hessian自相关矩阵即对Hessian行列式的相对权重的权重系数;

---------------------------------------------------------------------------------------------------------------------------------

代码实现

#include"stdafx.h"
#include <opencv2/opencv.hpp>
#include <iostream>#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>
#include <iostream>using namespace cv;
using namespace std;#define WIN_NAME "Shi-Tomasi角点检测"Mat srcImage, grayImage;
int maxCornerNumber = 33;
int maxTrackbarNumber = 500;
RNG rng(12345);void on_GoodFeatureToTrack(int, void *)
{if (maxCornerNumber <= 1){maxCornerNumber = 1;}//Shi-Tomasi参数准备vector<Point2f> corners;double qualityLevel = 0.01; //角点检测可以接受的最小特征值double minDistance = 10; //角点间的最小像素距离设置int blockSize = 3;  //计算导数自相关矩阵时指定的领域范围double k = 0.04;   //权重系数Mat copy = srcImage.clone(); //复制原图到一个临时变量中,作为感兴趣区域//Shi-Tomasi TestgoodFeaturesToTrack(grayImage, corners, maxCornerNumber, qualityLevel, minDistance, Mat(), blockSize, false, k);//输出文字信息cout << ">此次检测到的角点数量为: " << corners.size() << endl;//绘制检测到的角点for (unsigned int i = 0; i < corners.size(); i++){circle(copy, corners[i], 5, Scalar(rng.uniform(0, 255), rng.uniform(0, 255), rng.uniform(0, 255)), -1, 8, 0);}imshow(WIN_NAME, copy);
}int main(int argc, char** argv)
{srcImage = imread("F:/photo/lj.jpg");cvtColor(srcImage, grayImage, COLOR_BGR2GRAY);namedWindow(WIN_NAME, WINDOW_AUTOSIZE);createTrackbar("最大角点数:", WIN_NAME, &maxCornerNumber, maxTrackbarNumber, on_GoodFeatureToTrack);//imshow(WIN_NAME, srcImage);on_GoodFeatureToTrack(0, 0);waitKey(0);return 0;
}

-------------------------------------------------------------------------------------------------------------------------------- 

图像处理效果

这篇关于OpenCV图像特征提取学习二,Shi-Tomasi 角点检测算法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/483292

相关文章

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

Python脚本轻松实现检测麦克风功能

《Python脚本轻松实现检测麦克风功能》在进行音频处理或开发需要使用麦克风的应用程序时,确保麦克风功能正常是非常重要的,本文将介绍一个简单的Python脚本,能够帮助我们检测本地麦克风的功能,需要的... 目录轻松检测麦克风功能脚本介绍一、python环境准备二、代码解析三、使用方法四、知识扩展轻松检测麦

Python学习笔记之getattr和hasattr用法示例详解

《Python学习笔记之getattr和hasattr用法示例详解》在Python中,hasattr()、getattr()和setattr()是一组内置函数,用于对对象的属性进行操作和查询,这篇文章... 目录1.getattr用法详解1.1 基本作用1.2 示例1.3 原理2.hasattr用法详解2.

OpenCV在Java中的完整集成指南分享

《OpenCV在Java中的完整集成指南分享》本文详解了在Java中集成OpenCV的方法,涵盖jar包导入、dll配置、JNI路径设置及跨平台兼容性处理,提供了图像处理、特征检测、实时视频分析等应用... 目录1. OpenCV简介与应用领域1.1 OpenCV的诞生与发展1.2 OpenCV的应用领域2

在Java中使用OpenCV实践

《在Java中使用OpenCV实践》用户分享了在Java项目中集成OpenCV4.10.0的实践经验,涵盖库简介、Windows安装、依赖配置及灰度图测试,强调其在图像处理领域的多功能性,并计划后续探... 目录前言一 、OpenCV1.简介2.下载与安装3.目录说明二、在Java项目中使用三 、测试1.测

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

C++ 检测文件大小和文件传输的方法示例详解

《C++检测文件大小和文件传输的方法示例详解》文章介绍了在C/C++中获取文件大小的三种方法,推荐使用stat()函数,并详细说明了如何设计一次性发送压缩包的结构体及传输流程,包含CRC校验和自动解... 目录检测文件的大小✅ 方法一:使用 stat() 函数(推荐)✅ 用法示例:✅ 方法二:使用 fsee