博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
OpenCV教程(44) harris角的检测(2)
阅读量:7048 次
发布时间:2019-06-28

本文共 1044 字,大约阅读时间需要 3 分钟。

      在上一篇教程中,我们得到的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角检测图二值化后的结果,右边是检测结果局部最大化后的结果,可以看到局部最大化后,角的位置会有轻微的变化。

用下面的代码,我们可以得到最大值的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角图为(白色的点):

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

程序运行后,结果如下:

程序代码:参考FirstOpenCV48

代码下载:

转载于:https://www.cnblogs.com/mikewolf2002/p/3547437.html

你可能感兴趣的文章
Java第九次作业
查看>>
.Net Discovery系“.NET技术”列之-深入理解平台机制与性能影响 (中)
查看>>
1.文件重命名工具
查看>>
【java】json格式解析
查看>>
Linux开始结束ping命令
查看>>
开源一款私藏Management Studio插件,ProjkyAddin,送给所有使用SQLServer的园友们
查看>>
jQuery判断checkbox是否选中的3种方法
查看>>
LinkedList源码分析
查看>>
【算法介绍】哈希排序算法
查看>>
UpdatePanel and JQuery Plugin
查看>>
centos5.7下的kdump
查看>>
[JavaEE笔记]Cookie
查看>>
ELK+Filebeat (1)
查看>>
leetcode 443. String Compression
查看>>
在没联网环境下,启动tomcat出错
查看>>
关于Git bash-127.0.0.7:8888拒绝访问的小问题--环境变量
查看>>
有价值的数据
查看>>
LayUi超级好用的前端工具
查看>>
[Ubuntu] ubuntu的tty下挂载移动硬盘拷贝数据
查看>>
犯了个低级错误
查看>>