一、高斯平滑(模糊)

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及其他算子)的更多相关文章

  1. OpenCV3编程入门笔记(4)腐蚀、膨胀、开闭运算、漫水填充、金字塔、阈值化、霍夫变换

    腐蚀erode.膨胀dilate 腐蚀和膨胀是针对图像中的白色部分(高亮部分)而言的,不是黑色的.除了输入输出图像外,还需传入模板算子element,opencv中有三种可以选择:矩形MORPH_RE ...

  2. OpenCV计算机视觉学习(5)——形态学处理(腐蚀膨胀,开闭运算,礼帽黑帽,边缘检测)

    如果需要处理的原图及代码,请移步小编的GitHub地址 传送门:请点击我 如果点击有误:https://github.com/LeBron-Jian/ComputerVisionPractice 形态 ...

  3. OpenCV探索之路(四):膨胀、腐蚀、开闭运算

    腐蚀和膨胀是最基本的形态学运算. 腐蚀和膨胀是针对白色部分(高亮部分)而言的. 膨胀就是对图像高亮部分进行"领域扩张",效果图拥有比原图更大的高亮区域:腐蚀是原图中的高亮区域被蚕食 ...

  4. OpenCV学习(10) 图像的腐蚀与膨胀(1)

    建议大家看看网络视频教程:http://www.opencvchina.com/thread-886-1-1.html    腐蚀与膨胀都是针对灰度图的形态学操作,比如下面的一副16*16的灰度图. ...

  5. opencv学习之路(15)、形态学其他操作(开、闭、顶帽、黑帽、形态学梯度)

    一.形态学其他操作(用的不多,如果忘了也可以通过膨胀腐蚀得到相同效果) 1.开运算 2.闭运算 3.形态学梯度 4.顶帽 5.黑帽 #include "opencv2/opencv.hpp& ...

  6. OpenCV学习(11) 图像的腐蚀与膨胀(2)

    先对一副灰度图像进行腐蚀操作,然后在腐蚀后的图像上再进行膨胀操作,我们定义这个操作为开操作. 先对一副图像进行膨胀操作,然后在膨胀后的图像上再进行腐蚀操作,我们定义这个操作为闭操作.       开操 ...

  7. OpenCV学习(12) 图像的腐蚀与膨胀(3)

    通过使用不同的结构元素来进行膨胀腐蚀操作,可以检测图像中的角点,下面就一步一步看这个算法如果实现角点检测. 原图像: 首先我们创建四个结构元素 先用十字结构元素对原图像进行膨胀操作,得到下面的图像 再 ...

  8. OpenCV学习 7:图像形态学:腐蚀、膨胀

    原创文章,欢迎转载,转载请注明出处 首先什么是图像形态学?额,这个抄下百度到的答案.基本思想:    用具有一定形态的结构元素去度量和提取图像中的对应形状已达到对图像分析和识别的目的,形态学图像处理表 ...

  9. 【python-opencv】17-形态学操作-腐蚀与膨胀

    形态学操作其实就是改变物体的形状,比如腐蚀就是"变瘦",膨胀就是"变胖",看下图就明白了: 形态学操作一般作用于二值化图(也可直接作用于原图),来连接相邻的元素 ...

随机推荐

  1. C语言 俄罗斯方块的实现1 全局变量

    目录 全局变量 程序的模块化之MVC 关于俄罗斯方块的代码实现要点 使用数组表示背景和方块 方块表示及其初始化 要让游戏动起来 方块自动下落 全局变量 简而言之,定义在函数外的变量,就是全局变量. 所 ...

  2. 2019牛客暑期多校训练营(第二场)-H Second Large Rectangle(次大子矩阵,降维,直方图+单调栈)

    题目链接:https://ac.nowcoder.com/acm/contest/882/H 题目:给n×m的由01组成的矩阵,求次大全1子矩阵的大小. 思路:第一步还是降维操作,用a[i][j]记录 ...

  3. SQLite基础-2.PyCharm+Database_Navigator

    目录 一.PyCharm + Database Navigator插件 二.SQLite Expert – Personal Edition 三.SQLite Administrator 一.PyCh ...

  4. STL vector常见用法详解

    <算法笔记>中摘取 vector常见用法详解 1. vector的定义 vector<typename> name; //typename可以是任何基本类型,例如int, do ...

  5. python-day37(正式学习)

    前景回顾 抢票系统的代码优化,使用了Lock类 from multiprocessing import Process,Lock import os,time,json with open('user ...

  6. Transparency Tutorial with C# - Part 3

    Download image fade demo - 4 Kb Download image fade source project- 7 Kb Download image fade images ...

  7. sql server if else

    DECLARE IF (@sex = '1')BEGIN PRINT '2'END ELSE BEGIN PRINT(1) END begin... end可以省略 declare @sex int ...

  8. sql server case when

    case具有两种格式:简单Case函数和Case搜索函数 简单case函数 实例:CASE sex     when '1' then '男'     when '2' then'女'     els ...

  9. 第一个SpringMVC程序

    1.创建工程 2.导入依赖 3.编写配置文件(web.xml) 配置了SpringMVC的入口: 4.SpringMVC的配置文件 路径:默认情况下,在目录下找这个文件:/WEB-INF/{servl ...

  10. Spark 2.43读取.json文件入库到MySQL 8

    如果没有安装包,可以用我的这个 百度网盘链接点击进入 提取码: eku1 解压之后 准备开始配置环境变量 如果运行时候报错参考 (java.io.IOException: Could not loca ...