当前位置:   article > 正文

OpenCV-顶帽运算(TOPHAT)

顶帽运算

作者:翟天保Steven
版权声明:著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处

原理

       形态学是图像处理中常见的名词,图像处理的形态学基本属于数学形态学的范畴,是一门建立在格论和拓扑学基础上的图像分析学科。顶帽运算是结合了腐蚀和膨胀的一种运算,原图减开运算结果图。

       简单来说,顶帽运算就是将原图减去开运算后的图像,放大了裂痕或局部低亮度区域。效果图见下方图1图2。

函数原型

  1. void morphologyEx( InputArray src, OutputArray dst,
  2. int op, InputArray kernel,
  3. Point anchor = Point(-1,-1), int iterations = 1,
  4. int borderType = BORDER_CONSTANT,
  5. const Scalar& borderValue = morphologyDefaultBorderValue() );
  6. 其中op=MORPH_TOPHAT

参数说明

  1. InputArray类型的src,输入图像,如Mat类型。
  2. OutputArray类型的dst,输出图像。
  3. int类型的op,选择不同的运算操作,顶帽运算则是MORPH_TOPHAT。
  4. Point类型的anchor,锚点。默认值(-1,-1),表示位于单位中心,一般不用。
  5. int类型的iterations,迭代使用的次数,默认值为1。
  6. int类型的borderType,推断图像外部像素的边界模式,我OpenCV版本的默认值为BORDER_CONSTANT。如果图像边界需要扩展,则不同的模式下所扩展的像素,其生成原则不同。
  7. const Scalar&类型的borderValue,当边界为常数时的边界值,默认值为morphologyDefaultBorderValue()。

测试代码

  1. #include<iostream>
  2. #include<opencv2/opencv.hpp>
  3. #include<ctime>
  4. using namespace std;
  5. using namespace cv;
  6. int main(void)
  7. {
  8. cv::Mat test = cv::Mat::zeros(64, 64, CV_8UC1);
  9. cv::rectangle(test, cv::Rect(30, 30, 8, 8), 255, -1);
  10. cv::rectangle(test, cv::Rect(32, 28, 2, 2), 255, -1);
  11. cv::Mat element = getStructuringElement(MORPH_RECT, Size(3, 3));
  12. cv::Mat result,open;
  13. cv::morphologyEx(test, open, MORPH_OPEN, element);
  14. cv::morphologyEx(test, result, MORPH_TOPHAT, element);
  15. imshow("original", test);
  16. imshow("open", open);
  17. imshow("result", result);
  18. waitKey(0);
  19. system("pause");
  20. return 0;
  21. }

测试效果

图1 原图
图2 开运算结果图
图3 顶帽运算结果图

       如上图所示,有原先8*8的矩形,外加一个2*2的凸起,我设置了3*3的矩形蒙版,对其进行开运算操作如图2所示,凸起消失,对其进行顶帽操作如图3所示,突出了开运算消除的内容。

       如果文章帮助到你了,可以点个赞让我知道,我会很快乐~加油!

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家小花儿/article/detail/86615
推荐阅读
相关标签
  

闽ICP备14008679号