当前位置: 首页 > article >正文

OpenCV特征检测(5)检测图像中的角点函数cornerMinEigenVal()的使用

  • 操作系统:ubuntu22.04
  • OpenCV版本:OpenCV4.9
  • IDE:Visual Studio Code
  • 编程语言:C++11

算法描述

计算用于角点检测的梯度矩阵的最小特征值。

该函数类似于 cornerEigenValsAndVecs,但它计算并存储协方差矩阵导数的最小特征值,即在 cornerEigenValsAndVecs 描述中的公式里的 min(λ1, λ2)。
cv::cornerMinEigenVal 是 OpenCV 中的一个函数,用于检测图像中的角点。该函数计算每个像素周围的协方差矩阵,并返回最小特征值。最小特征值可以用来识别图像中的角点,因为角点通常会在多个方向上有较大的强度变化。

函数原型


void cv::cornerMinEigenVal
(
	InputArray 	src,
	OutputArray 	dst,
	int 	blockSize,
	int 	ksize = 3,
	int 	borderType = BORDER_DEFAULT 
)		

参数

  • 参数src 输入单通道 8 位或浮点图像。
  • 参数dst 用于存储最小特征值的图像。它具有类型 CV_32FC1 并且大小与 src 相同。
  • 参数blockSize 邻域大小(参见 cornerEigenValsAndVecs 的详细信息)。
  • 参数ksize Sobel 操作符的孔径参数。
  • 参数borderType 像素外推方法。参见 BorderTypes。不支持 BORDER_WRAP。

代码示例


#include <iostream>
#include <opencv2/opencv.hpp>

int main()
{
    // 加载图像
    cv::Mat img = cv::imread( "/media/dingxin/data/study/OpenCV/sources/images/hawk.jpg", cv::IMREAD_GRAYSCALE );
    if ( img.empty() )
    {
        std::cout << "Error opening image" << std::endl;
        return -1;
    }

    // 计算最小特征值
    cv::Mat minEigenVal;
    int blockSize  = 3;                   // 邻域大小
    int ksize      = 3;                   // Sobel 梯度算子的大小
    int borderType = cv::BORDER_DEFAULT;  // 边界处理类型

    cv::cornerMinEigenVal( img, minEigenVal, blockSize, ksize, borderType );

    // 显示最小特征值图像
    cv::normalize( minEigenVal, minEigenVal, 0, 255, cv::NORM_MINMAX, CV_8U );
   

    cv::imshow( "Original Image", img );
    cv::imshow( "Min Eigen Value", minEigenVal );

    cv::waitKey( 0 );

    return 0;
}

运行结果

在这里插入图片描述

原文地址:https://blog.csdn.net/jndingxin/article/details/142392134
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.kler.cn/a/317301.html

相关文章:

  • java spring,uName,kValue,前端传值后端接不到
  • css中的阴影详解
  • 如何在谷歌浏览器中设置自定义安全警告
  • nginx 的基础语法学习,零基础学习
  • JAVA实现五子棋小游戏(附源码)
  • Scala语言的多线程编程
  • 【TS】TypeScript基础入门篇以及实践案例
  • 中间件:maxwell、canal
  • Unity 高亮插件HighlightPlus介绍
  • Node.js backend for OpenAI image generation giving error code 400
  • Excel导入时,一个简单的匹配中文外键的方法
  • 防护装备穿戴与否检测系统源码分享
  • Vue.js Emit
  • 多旋翼无人机维修、组装、调试技术详解
  • typora使用和激活
  • 【机器学习】生成对抗网络(GAN)——生成新数据的神经网络
  • 共建智能座舱AI应用生态 夸克合作斑马智行开拓AI搜索新场景
  • 【Linux】SSH:远程连接
  • python 项目中使用Elasticsearch
  • Qt Creator项目模板介绍
  • 使用OVPN导致电脑网速变慢的原因
  • MySQL record 08 part
  • 成功使用DDNS动态域名访问我的群晖NAS(TP-link路由器)
  • Yocto - 使用Yocto开发嵌入式Linux系统_03 基于Poky制作第一个系统
  • vue.js 展示一个树形结构的数据视图,并禁用其中默认选中的节点
  • java并发之并发理论