OpenCV教程(44) harris角的检测(2)

      在上一篇教程中,我们得到的harris特征角二值图中,角的数目特别多,本章我们用一个局部最大化的方法,只保留局部值最大的harris特征角。

// Harris角计算
cv::cornerHarris(image,cornerStrength,
        neighbourhood, // neighborhood size
        aperture,     // aperture size
        k);           // Harris parameter   
// internal threshold computation
double minStrength;

得到harris角结果图中的最小值,最大值。
cv::minMaxLoc(cornerStrength,
     &minStrength,&maxStrength);

// local maxima detection
cv::Mat dilated;  // temporary image

    使用一个膨胀操作,这样局部的值都会变为最大的值,然后再比较操作,这样localMax中,最大值位置的像素值为255,其它则为0。
cv::dilate(cornerStrength,dilated,cv::Mat());
cv::compare(cornerStrength,dilated,
            localMax,cv::CMP_EQ);

      下面左边的图是原始harris角检测图二值化后的结果,右边是检测结果局部最大化后的结果,可以看到局部最大化后,角的位置会有轻微的变化。

imageimage
用下面的代码,我们可以得到最大值的harris角,而对于其它值的角则移去。

cv::threshold(cornerStrength,cornerTh,
              threshold,255,cv::THRESH_BINARY);
// convert to 8-bit image
cornerTh.convertTo(cornerMap,CV_8U);   
// non-maxima suppression
cv::bitwise_and(cornerMap,localMax,cornerMap);

去掉其它值的角后,harris角图为(白色的点):

image

对于cornerMap的点,我们可以用一个circle来标记它。

程序运行后,结果如下:

image

程序代码:参考FirstOpenCV48

代码下载:http://yunpan.cn/Q4a6K68ASC5Xy

posted on   迈克老狼2012  阅读(914)  评论(2编辑  收藏  举报

编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· Vue3状态管理终极指南:Pinia保姆级教程

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示