OpenCV笔记(2)(高斯平滑、腐蚀和膨胀、开闭运算、礼帽和黑帽、Sobel及其他算子)
一、高斯平滑(模糊)
def gaussian_blur(image):
# 设置ksize来确定模糊效果
img = cv.GaussianBlur(image, (5, 5), 0)
cv.imshow('img', img) # 不通过ksize来设置高斯核大小,通过设置高斯分布公式中的sigma
img2 = cv.GaussianBlur(image, (0, 0), 1)
cv.imshow('img2', img2)

在高斯平滑中,高斯核中所有数字加起来应该为1,这样才能保证图片只发生平滑效果,而不影响亮度等其他效果。
例如3x3的高斯核如下所示:

二、边缘保留滤波(EPF)
高斯双边模糊(美颜):
def bi_blur(image):
img = cv.bilateralFilter(image, 0, 100, 5)
cv.imshow('img', img)

从效果可以看出,边缘保留的还不错,而非边缘进行了模糊。双边模糊的效率比较低,特别是sigmaSpace比较大的时候。
cv.bilateralFilter()函数的参数:
src:原图像
d:过滤过程中每个像素领域的直径范围,若非正数,则从sigmaSpace计算
sigmaColor:值越大,表示像素领域内有多宽的颜色(颜色范围)会被混在一起
sigmaSpace:如果值较大,表示颜色相近的较远像素(空间范围)将互相影响,从而使更大区域足够相似的颜色获取相同的颜色。
三、腐蚀和膨胀
腐蚀操作:
# 腐蚀操作,用于去除一些细小的白色颗粒或线条
def erode_img(image):
kernel = np.ones((5,5),np.uint8)
# 当核尺寸越大时,每次腐蚀的程度越大,iter是操作中叠加几次腐蚀
img = cv.erode(image,kernel,iterations = 1)
cv.imshow('img',img)

膨胀操作:
膨胀可以说是腐蚀的反操作:
# 膨胀操作,用于去除一些细小的黑色漏洞
def dilate_img(image):
kernel = np.ones((5, 5), np.uint8)
img = cv.dilate(image, kernel, iterations=1)
cv.imshow('img', img)

结合腐蚀和膨胀:
结合腐蚀和膨胀,可以消除一些细小的不需要的部分,然后再复原。
def combo_proc(image):
kernel = np.ones((5, 5), np.uint8)
img = cv.dilate(image, kernel, iterations=1)
img2 = cv.erode(img, kernel, iterations=1)
cv.imshow('img2', img2)

四、开运算和闭运算
# 开操作:先腐蚀再膨胀
def open_proc(image):
kernel = np.ones((5, 5), np.uint8)
opening = cv.morphologyEx(image, cv.MORPH_OPEN, kernel)
cv.imshow('opening', opening) # 闭操作:先膨胀再腐蚀
def close_proc(image):
kernel = np.ones((5, 5), np.uint8)
closing = cv.morphologyEx(image, cv.MORPH_CLOSE, kernel)
cv.imshow('closing', closing)

结合开闭运算:
# 先做开操作,再做闭操作
def open_close_proc(image):
kernel = np.ones((5, 5), np.uint8)
opening = cv.morphologyEx(image, cv.MORPH_OPEN, kernel)
closing = cv.morphologyEx(opening, cv.MORPH_CLOSE, kernel)
cv.imshow('closing', closing)

梯度运算:
# 梯度操作:膨胀 - 腐蚀
def gradient_proc(image):
kernel = np.ones((3, 3), np.uint8)
gradient = cv.morphologyEx(image, cv.MORPH_GRADIENT, kernel)
cv.imshow('gradient', gradient)

五、礼帽和黑帽
礼帽是通过原图片减去开操作后的图像,得到其中的多于细小部分(字边上的白色细线)。
黑帽是通过闭操作后的图像减去原图像,得到其中的细小泄漏部分(字中间的黑色细线)。
礼帽:tophat
# tophat 礼帽
def tophat_img(image):
kernel = np.ones((3, 3), np.uint8)
img = cv.morphologyEx(image, cv.MORPH_TOPHAT, kernel)
cv.imshow('img', img)

黑帽:blackhat
# blackhat 黑帽
def blackhat_img(image):
kernel = np.ones((3, 3), np.uint8)
img = cv.morphologyEx(image, cv.MORPH_BLACKHAT, kernel)
cv.imshow('img', img)

六、Sobel算子
def sobel_proc(image):
# 这里的cv.CV_64F用来保存所有的梯度(不管正负),1,0是dx,dy表示计算横向梯度
sobelx = cv.Sobel(image, cv.CV_64F, 1, 0, ksize=3)
# 将所有梯度取绝对值
sobelx = cv.convertScaleAbs(sobelx)
cv.imshow('sobelx', sobelx) # 计算y方向的梯度
sobely = cv.Sobel(image, cv.CV_64F, 0, 1, ksize=3)
# 将所有梯度取绝对值
sobely = cv.convertScaleAbs(sobely)
cv.imshow('sobely', sobely)

当计算X,Y方向的梯度时,Sobel算子分别为:

X方向是右边像素减去左边像素,Y方向是上面像素减去下面的像素。
将XY方向的梯度合并起来:
def sobel_proc(image):
# 这里的cv.CV_64F用来保存所有的梯度(不管正负),1,0是dx,dy表示计算横向梯度
sobelx = cv.Sobel(image, cv.CV_64F, 1, 0, ksize=3)
# 将所有梯度取绝对值
sobelx = cv.convertScaleAbs(sobelx)
# cv.imshow('sobelx', sobelx) # 计算y方向的梯度
sobely = cv.Sobel(image, cv.CV_64F, 0, 1, ksize=3)
# 将所有梯度取绝对值
sobely = cv.convertScaleAbs(sobely)
# cv.imshow('sobely', sobely) # 将x和y方向的梯度合并起来,类似于sobelx+sobely
sobelxy = cv.addWeighted(sobelx, 1, sobely, 1, 0)
cv.imshow('sobelxy', sobelxy) # 不建议使用这种方式,有问题
sobelxy2 = cv.Sobel(image, -1, 1, 1, ksize=3)
cv.imshow('sobelxy2', sobelxy2)

建议使用addWeight()的方式进行合并,而不建议在一个Sobel计算中同时计算xy方向的梯度。
应用到图片上:
彩色图:

灰度图:

七、其他算子介绍
Scharr算子:(读/ʃɑr/)

scharr = cv.Scharr(image,cv.CV_64F, 1, 0)
scharr = cv.convertScaleAbs(scharr)
Scharr算子和Sobel算子类似,只是数值比Sobel大很多,这就导致Scharr算子灵敏度更高,噪声影响较大。如下图:

Laplacian算子:
拉普拉斯算子是图像的离散二阶导数,用于发现边缘突变,但对于噪声来说比较灵敏,一般配合其他技术一起使用。


laplacian = cv.Laplacian(image,cv.CV_64F)
laplacian = cv.convertScaleAbs(laplacian)
Laplacian算是和前面的两种算子不同,前面的两种算子都属于一阶导数,而Laplacian算子是用于计算二阶导数的。体现的是边缘的突变度,即梯度的变化度。效果如图:

OpenCV笔记(2)(高斯平滑、腐蚀和膨胀、开闭运算、礼帽和黑帽、Sobel及其他算子)的更多相关文章
- OpenCV3编程入门笔记(4)腐蚀、膨胀、开闭运算、漫水填充、金字塔、阈值化、霍夫变换
腐蚀erode.膨胀dilate 腐蚀和膨胀是针对图像中的白色部分(高亮部分)而言的,不是黑色的.除了输入输出图像外,还需传入模板算子element,opencv中有三种可以选择:矩形MORPH_RE ...
- OpenCV计算机视觉学习(5)——形态学处理(腐蚀膨胀,开闭运算,礼帽黑帽,边缘检测)
如果需要处理的原图及代码,请移步小编的GitHub地址 传送门:请点击我 如果点击有误:https://github.com/LeBron-Jian/ComputerVisionPractice 形态 ...
- OpenCV探索之路(四):膨胀、腐蚀、开闭运算
腐蚀和膨胀是最基本的形态学运算. 腐蚀和膨胀是针对白色部分(高亮部分)而言的. 膨胀就是对图像高亮部分进行"领域扩张",效果图拥有比原图更大的高亮区域:腐蚀是原图中的高亮区域被蚕食 ...
- OpenCV学习(10) 图像的腐蚀与膨胀(1)
建议大家看看网络视频教程:http://www.opencvchina.com/thread-886-1-1.html 腐蚀与膨胀都是针对灰度图的形态学操作,比如下面的一副16*16的灰度图. ...
- opencv学习之路(15)、形态学其他操作(开、闭、顶帽、黑帽、形态学梯度)
一.形态学其他操作(用的不多,如果忘了也可以通过膨胀腐蚀得到相同效果) 1.开运算 2.闭运算 3.形态学梯度 4.顶帽 5.黑帽 #include "opencv2/opencv.hpp& ...
- OpenCV学习(11) 图像的腐蚀与膨胀(2)
先对一副灰度图像进行腐蚀操作,然后在腐蚀后的图像上再进行膨胀操作,我们定义这个操作为开操作. 先对一副图像进行膨胀操作,然后在膨胀后的图像上再进行腐蚀操作,我们定义这个操作为闭操作. 开操 ...
- OpenCV学习(12) 图像的腐蚀与膨胀(3)
通过使用不同的结构元素来进行膨胀腐蚀操作,可以检测图像中的角点,下面就一步一步看这个算法如果实现角点检测. 原图像: 首先我们创建四个结构元素 先用十字结构元素对原图像进行膨胀操作,得到下面的图像 再 ...
- OpenCV学习 7:图像形态学:腐蚀、膨胀
原创文章,欢迎转载,转载请注明出处 首先什么是图像形态学?额,这个抄下百度到的答案.基本思想: 用具有一定形态的结构元素去度量和提取图像中的对应形状已达到对图像分析和识别的目的,形态学图像处理表 ...
- 【python-opencv】17-形态学操作-腐蚀与膨胀
形态学操作其实就是改变物体的形状,比如腐蚀就是"变瘦",膨胀就是"变胖",看下图就明白了: 形态学操作一般作用于二值化图(也可直接作用于原图),来连接相邻的元素 ...
随机推荐
- 菜鸟系列Fabric——Fabric 网络架构介绍(4)
Fabric 网络架构介绍 1. 网络架构介绍 如图所示,fabric网络架构主要包含客户端节点.CA节点.Peer节点.Orderer节点这几个部分.并且fabric架构是安装组织来进行划分当,每个 ...
- 【Linux-驱动】在sysfs下创建对应的class节点---class_create
在编写简单字符设备驱动的时候,可以使用宏class_create在sysfs下创建对应的class节点,便于用户管理设备: #define class_create(owner, name) \ ({ ...
- Shell初学(五)bash shell的基本功能
记住,所谓的bash shell 并不单纯指的是shell脚本,其实是Linux系统的所有指令集. shell脚本 只是汇总了指令集到文件,然后按流程和顺序执行. [1]如何查看我们的预设shell ...
- jQuery扁平化风格手风琴菜单
在线演示 本地下载
- ProGuard 最全混淆规则说明
Input/Output Options 输入输出选项 -include filename 递归引入目录的配置文件 -basedirectory directoryname -injars class ...
- Dubbo消费方服务调用过程源码分析
参考:dubbo消费方服务调用过程源码分析dubbo基于spring的构建分析Dubbo概述--调用过程dubbo 请求调用过程分析dubbo集群容错机制代码分析1dubbo集群容错策略的代码分析2d ...
- C++ 友元(friend关键字)、类中的重载、操作符重载(operator关键字)
C++ 中友元的用法: 1.在类中使用friend关键字声明 2.类的友元可以是其它类或者具体函数 3.友元不是类的一部分 4.友元不受类中访问级别的限制 5.友元可以直接访问具体类中的所有成员. 友 ...
- response.getWriter().wirte和out.print()的区别
1.首先介绍write()和print()方法的区别: (1).write():仅支持输出字符类型数据,字符.字符数组.字符串等 (2).print():可以将各种类型(包括Object)的数据通 ...
- MVC 部署到服务器
1.Nuget程序包管理 —>程序包管理控制台,运行以下命令即可:Update-Package Microsoft.AspNet.WebApi -reinstall 2.dll文件的缺少,覆盖
- Binding的Path(路径)
Binding的源可以是控件(一个控件是另一个控件的Source.控件把自己的容器作为Source),把集合作为ItemsControls的Source,把xml作为Tree或者Menu的Source ...