一、腐蚀和膨胀

1、腐蚀和膨胀的主要功能

(1)消除噪声

(2)分割出独立的图像元素,在图像中连接相邻的元素

(3)寻找图像中的极大值或者极小值区域

(4)求出图像的梯度

2、膨胀(dilate)

膨胀就是求局部最大值的操作。从数学角度来说,就是将图像与核进行卷积,计算核B覆盖区域的像素点的最大值,并把这个最大值赋值给参考点指定的元素。这样就会使图像中的高亮区域逐渐增长。

3、腐蚀(erode)

腐蚀和膨胀是相反的操作,腐蚀是求局部最小值的操作。腐蚀操作会使图像中的高亮区逐渐减小。

4、膨胀和腐蚀示例

 Mat srcImage = imread("E:\\CodeResource\\opencv\\car_pic\\car1.jpg",);

 Mat element = getStructuringElement(MORPH_RECT, Size(, ));

 Mat dilateImage;
dilate(srcImage, dilateImage, element); Mat erodeImage;
erode(srcImage, erodeImage, element); imshow("srcImage", srcImage);
imshow("dilateImage", dilateImage);
imshow("erodeImage", erodeImage); waitKey();

5、效果图:

二、开运算

1、概述

开运算是先腐蚀后膨胀。主要用于消除小物体,在纤细点处分离物体,并且在平滑较大物体的边界的同时不明显改变其面积,同时抑制比结构元小的亮细节。

2、示例

 Mat srcImage = imread("E:\\CodeResource\\opencv\\car_pic\\test1.png",);

 Mat element = getStructuringElement(MORPH_RECT, Size(,));

 Mat openImage;
morphologyEx(srcImage, openImage, MORPH_OPEN, element); imshow("srcImage", srcImage);
imshow("openImage", openImage); waitKey();

3、效果图

三、闭运算

1、概述

闭运算是先膨胀后腐蚀。用来填充物体内细小空洞、连接邻近物体、平滑其边界的同时并不明显改变其面积,同时抑制比结构元小的暗细节。

2、示例

 Mat srcImage = imread("E:\\CodeResource\\opencv\\car_pic\\test2.png",);

 Mat element = getStructuringElement(MORPH_RECT, Size(,));

 Mat closeImage;
morphologyEx(srcImage, closeImage, MORPH_CLOSE, element); imshow("srcImage", srcImage);
imshow("closeImage", closeImage); waitKey();

3、效果图

四、形态学梯度

1、概述

就是将膨胀土和腐蚀图相减。对二值化图像进行这一操作可以将边缘突出来,可以使用形态学梯度来保留物体的边缘轮廓

2、示例

 Mat srcImage = imread("E:\\CodeResource\\opencv\\car_pic\\test2.png",);

 Mat element = getStructuringElement(MORPH_RECT, Size(,));

 Mat gradientImage;
morphologyEx(srcImage, gradientImage, MORPH_GRADIENT, element); imshow("srcImage", srcImage);
imshow("gradientImage", gradientImage); waitKey();

3、效果图

五、顶帽变换和黑帽变换

1、概述

顶帽变换就是用源图像减去开运算图像。因为开运算带来的结果是放大了裂缝或者局部低亮度的区域。因此,从原图中减去开运算后的图,得到的效果图突出了比原图轮廓周围区域更明亮的区域。顶帽一般用于校正不均匀光照的影响(补充:均匀光照在从背景中提取目标的处理中扮演核心的角色)。

黑帽变换就是用闭运算减去源图像。黑帽运算后的效果图突出了比原图轮廓周围的区域更暗的区域。黑帽运算一般用来分离比邻近点暗一些的斑块。

2、示例

 Mat srcImage = imread("E:\\CodeResource\\opencv\\car_pic\\test2.png",);

 Mat element = getStructuringElement(MORPH_RECT, Size(,));

 Mat tophatImage;
morphologyEx(srcImage, tophatImage, MORPH_TOPHAT, element); Mat blackhatImage;
morphologyEx(srcImage, blackhatImage, MORPH_BLACKHAT, element); imshow("srcImage", srcImage);
imshow("tophatImage", tophatImage);
imshow("blackhatImage", blackhatImage); waitKey();

3、效果图

参考:http://blog.csdn.net/hx1298234467/article/details/49887925

OpenCV3编程入门读书笔记4-形态学滤波的更多相关文章

  1. OpenCV3编程入门读书笔记5-边缘检测

    一.边缘检测的一般步骤 1.滤波 边缘检测的算法主要是基于图像强度的一阶和二阶导数,但导数通常对噪声很敏感,因此必须采用滤波器来改善与噪声有关的边缘检测器的性能. 2.增强 增强边缘的基础是确定图像各 ...

  2. OpenCV3编程入门-读书笔记3-滤波

    一.领域滤波(卷积) 邻域算子值利用给定像素周围像素的值决定此像素的最终输出.如图左边图像与中间图像卷积得到右边图像.目标图像中绿色的像素由原图像中蓝色标记的像素计算得到. 通用线性邻域滤波是一种常用 ...

  3. OpenCV3编程入门-读书笔记2-core组件

    一.颜色空间缩减 1.概念 如果图像是3通道,深度为1个字节,则每个像素有256*256*256种可能值,这么多的可能值会对算法性能造成严重影响.利用颜色空间缩减就能解决这个问题,例如将颜色值0~9取 ...

  4. OpenCV3编程入门-读书笔记1

    一.OpenCV概述 1.OpenCV全程Open Source Computer Vision Library,即开源计算机视觉库.它是一个跨平台的开源计算机视觉库,可以运行在windows.lin ...

  5. opencv3 编程入门学习笔记(一): 基本函数介绍

    滤波 blur (均值滤波) 均值滤波是典型的线性滤波算法, 主要方法为领域平均法(即用一片图像区域的各个像素的平均值来代替原图像中的各个像素值) 缺点: 不能很好的保护图像细节, 在图像去噪的同时也 ...

  6. 【浅墨著作】《OpenCV3编程入门》内容简单介绍&勘误&配套源码下载

    经过近一年的沉淀和总结,<OpenCV3编程入门>一书最终和大家见面了. 近期有为数不少的小伙伴们发邮件给浅墨建议最好在博客里面贴出这本书的文件夹,方便大家更好的了解这本书的内容.事实上近 ...

  7. OpenCV3编程入门.记录

    ZC:OpenCV3编程入门_毛星云编著_电子工业出版.pdf 1.在看到 PDF.P134(计算数组加权和:addWeighted()函数)的时候,其中讲到“当输出数组的深度为CV_32S时,这个函 ...

  8. 《C#高级编程》读书笔记

    <C#高级编程>读书笔记 C#类型的取值范围 名称 CTS类型 说明 范围 sbyte System.SByte 8位有符号的整数 -128~127(−27−27~27−127−1) sh ...

  9. 第三章 Git的入门 - 读书笔记

    Android驱动月考3 第三章 Git的入门 - 读书笔记 对于Github,这是全世界最大的开源平台,你可以把你做的项目在这里开源,把你发现的一些新技术在这里开源,向全世界的开发者们分享,大家都彼 ...

随机推荐

  1. 求100之内的素质并输出(最优算法)-PHP面试题

    曾经第一次面试题中的题目, 今天碰巧看到整理一下 当时用了最基本的算法写出来了, 两个for循环, 一个一个取余, 是质数就放进结果数组中 代码如下, 检查代码运行时间的代码是来对比三种不同算法的优劣 ...

  2. CKEditor 4.5 filetools, XHR.withCredentials = true,

    var editor = CKEDITOR.replace( 'editor1', { extraPlugins: 'uploadimage,filetools', imageUploadUrl: ' ...

  3. flex知识点归纳

    1.flex-shrink <div id="content"> <div class="box" style="backgroun ...

  4. js对象取值的两种方式

    :"李四"}; var v1 = obj.name1; //张三, 使用点的方式 //报错,不能使用点的方式 ]; //李四,使用中括号的方式 var key = "na ...

  5. springboot 打war

    pom.xml <packaging>war</packaging> <!-- 打包设置 --> <plugins> <plugin> &l ...

  6. 源码编译安装php7

    现在新启的项目都是采用php7了,无奈很多Linux发行版中还是php5 第三方php7源在自己本机上用用到无所谓,放到正式环境上还是有点不放心 其实编译安装也就几分钟,麻烦的是各种依赖 先删除老版本 ...

  7. ExcelTools使用

    using NPOI.SS.Formula.Functions; using NPOI.SS.UserModel; using System; using System.Collections.Gen ...

  8. 11.2 Flask 配置文件,路由系统

    配置文件系统 构建 Flask 应用时指定 app = Flask( __name__, template_folder = '', # 指定存储模板文件夹名称 static_url_path = ' ...

  9. Scrapy 框架 中间件,信号,定制命令

    中间件 下载器中间件 写中间件 from scrapy.http import HtmlResponse from scrapy.http import Request class Md1(objec ...

  10. BZOJ 1671: [Usaco2005 Dec]Knights of Ni 骑士 (bfs)

    题目: https://www.lydsy.com/JudgeOnline/problem.php?id=1671 题解: 按题意分别从贝茜和骑士bfs然后meet_in_middle.. 把一个逗号 ...