opencv 之 图像基本形态学处理

1.腐蚀与膨胀

腐蚀

所谓腐蚀就是腐蚀图像的边缘,让图像往里缩,腐蚀程度, 取决于卷积核的大小

import cv2
import matplotlib.pyplot as plt
import numpy as np

#  圆的腐蚀案例   可以看到, 每次腐蚀,都会往里边缩
img_circle = cv2.imread('circle.png')

# 下边的这个kernel 表示腐蚀核的大小,核越小,腐蚀程度越小
kernel = np.ones((30, 30), np.uint8)
erosion_1 = cv2.erode(img_circle, kernel, iterations = 1)  # 后边这个表示腐蚀次数, 次数越多,腐蚀越厉害
erosion_2 = cv2.erode(img_circle, kernel, iterations = 2)
erosion_3 = cv2.erode(img_circle, kernel, iterations = 3)

plt.figure(figsize = (12, 12))

plt.subplot(2, 2, 1), plt.imshow(img_circle), plt.title('original')
plt.subplot(2, 2, 2), plt.imshow(erosion_1), plt.title('erosion_1')
plt.subplot(2, 2, 3), plt.imshow(erosion_2), plt.title('erosion_2')
plt.subplot(2, 2, 4), plt.imshow(erosion_3), plt.title('erosion_3')

在这里插入图片描述
调整卷积核kernel的大小, 腐蚀程度会随之变化, 如下是腐蚀的一个案例, 去掉边缘多出来的毛刺

import cv2
import matplotlib.pyplot as plt
import numpy as np

img = cv2.imread("fushi.jpg")

kernel = np.ones((5, 5), np.uint8)  # 腐蚀卷积核的大小
erosion = cv2.erode(img, kernel, iterations = 1)  # 后边的iterations表示腐蚀的次数

plt.figure(figsize=(25, 12))

plt.subplot(2, 3, 1), plt.imshow(img), plt.title('original')
plt.subplot(2, 3, 2), plt.imshow(erosion), plt.title('erosion')

在这里插入图片描述
腐蚀操作有很好的,去掉毛刺的效果

膨胀
# 膨胀类似于腐蚀的逆运算
# 如果我们想把上边的 腐蚀操作的毛刺儿去掉,就可以先腐蚀,再膨胀,就可以

img = cv2.imread('fushi.jpg')

kernel = np.ones((5, 5), np.uint8)
dilate_1 = cv2.dilate(img, kernel, iterations = 1)

plt.figure(figsize=(25, 12))

plt.subplot(2, 3, 1), plt.imshow(img), plt.title('original')
plt.subplot(2, 3, 2), plt.imshow(dilate_1), plt.title('dilate_1')

在这里插入图片描述
所谓膨胀就是往外扩, 类似于侵略

2. 开闭运算

开运算
# 开运算相当于是先腐蚀,再膨胀,可以达到去除毛刺的效果
import cv2
import matplotlib.pyplot as plt
import numpy as np

img = cv2.imread('fushi.jpg')

kernel = np.ones((5, 5), np.uint8)
opening = cv2.morphologyEx(img, cv2.MORPH_OPEN, kernel)

plt.figure(figsize=(12, 12))
plt.subplot(2, 2, 1), plt.imshow(img), plt.title('original')
plt.subplot(2, 2, 2), plt.imshow(opening), plt.title('opening')

在这里插入图片描述

闭运算
# 闭运算则是先膨胀, 再腐蚀

import cv2
import matplotlib.pyplot as plt
import numpy as np

img = cv2.imread('fushi.jpg')

kernel = np.ones((5, 5), np.uint8)
closing = cv2.morphologyEx(img, cv2.MORPH_CLOSE, kernel)

plt.figure(figsize=(12, 12))
plt.subplot(2, 2, 1), plt.imshow(img), plt.title('original')
plt.subplot(2, 2, 2), plt.imshow(closing), plt.title('colsing')

在这里插入图片描述

3.梯度处理

###  梯度运算 = 膨胀 - 腐蚀
import cv2
import matplotlib.pyplot as plt
import numpy as np

img = cv2.imread('circle.png')

kernel = np.ones((7, 7), np.uint8)

dilate = cv2.dilate(img, kernel, iterations = 2)    # 膨胀
erosion = cv2.erode(img, kernel, iterations = 2)    # 腐蚀
gradient = cv2.morphologyEx(img, cv2.MORPH_GRADIENT, kernel)    # 梯度运算

plt.figure(figsize=(12, 12))

plt.subplot(2, 2, 1), plt.imshow(dilate), plt.title("dilate")
plt.subplot(2, 2, 2), plt.imshow(erosion), plt.title("erosion")
plt.subplot(2, 2, 3), plt.imshow(gradient), plt.title("gradient")

在这里插入图片描述
可以看到,膨胀减去腐蚀就是边缘部分

4. 礼帽与黒帽

礼帽: 原始输入 - 开运算结果
# 所谓原始图像就是最先的图像,开运算的结果就是去毛刺之后的,所以,
# 原来的减去去毛刺的就是只剩下毛刺的

img = cv2.imread('fushi.jpg')

kernel = np.ones((7, 7), np.uint8)
tophat = cv2.morphologyEx(img, cv2.MORPH_TOPHAT, kernel)

plt.figure(figsize=(12, 12))

plt.subplot(2, 2, 1), plt.imshow(img), plt.title("original")
plt.subplot(2, 2, 2), plt.imshow(tophat), plt.title("tophat")

在这里插入图片描述

黒帽 : 闭运算 - 原始输入
# 闭运算得到的结果是 图像的边缘部分

img = cv2.imread('fushi.jpg')

kernel = np.ones((7, 7), np.uint8)
tophat = cv2.morphologyEx(img, cv2.MORPH_BLACKHAT, kernel)

plt.figure(figsize=(12, 12))

plt.subplot(2, 2, 1), plt.imshow(img), plt.title("original")
plt.subplot(2, 2, 2), plt.imshow(tophat), plt.title("blackhat")

在这里插入图片描述

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【课程简介】 本课程基于面向Python的OpenCV,以OpenCV的官方文档的知识脉络为主线,介绍了OpenCV函数的具体使用方法、函数所使用的算法的具体原理。 在介绍函数使用时,提供了大量的程序案例演示。 在介绍具体原理时,采用了通俗易懂的语言和贴近生活的示例来说明问题,尽量避免涉及过于复杂抽象的公式。 课程包含数字图像处理的常用知识点,覆盖面全,方便学员系统深入全面地掌握OpenCV。 【你将收获什么】 1.  掌握数字图像的在计算机内表示的方法和处理基本原理。掌握数字图像的表示方法是进行图像处理的前提和基础,能够为后续的智能图像处理打下坚实基础。 2.  使用好OpenCV开源库对于提升工作效率具有很大的帮助。OpenCV是优秀的开源库,提供了大量的函数帮助我们提升工作效率。大多数情况下,我们直接调用函数就能够满足我们的需求。同时,它的函数具有较好的交互性,能够根据需要更好地掌控图像处理的具体细节。 3.  学习图像处理的常用算法。课程不仅介绍函数的具体使用,也介绍了常用算法的基本原理,帮助学习者更好地理解图像处理基本逻辑、方法,快速入门图像处理领域。 【我将如何教你】 1)在“黑盒”和“白盒“之间取得平衡  可以将OpenCV看成“黑盒”,不用关心其函数是如何实现的。在需要实现某一个功能时,直接调用其对应的函数即可,像使用Photoshop的各种功能一样。也可以将OpenCV看成“白盒”,关注其每一个函数的具体实现,认真研究每一个函数的具体实现方法和实现细节。这两种方式都是学习图像处理的很好方式,但是大多数课程过于强调其中某一种,要么忽略了算法的实现、要么忽略了使用方法。本课程尽量将OpenCV在“黑盒”和“白盒”之间取得平衡。既介绍算法的原理和方法,又将重点放在如何调用函数上,让学习者能够更加游刃有余地在计算机视觉项目中使用OpenCV来解决具体的问题。 2)将枯燥的算法采用具体的案例介绍  在图像处理中,有大量的算法保证了图像处理的准确、高效。OpenCV将一些常用的算法进行了封装,我们可以直接调用OpenCV的函数来使用对应的算法。但是,深入地理解算法能够帮助学习者更好地使用OpenCV函数。本课程尝试抛弃传统的使用复杂公式介绍算法的形式,尽量通过简单、通俗易懂的生活中实例来帮助学习者理解算法的基本逻辑 3)案例驱动、强调实战 OpenCV是一个庞大的资源库,提供了非常多的函数帮助我们高效地处理问题。初学者使用OpenCV的最大困惑就是熟练地掌握了每一个函数的调用方法,但是在解决实际问题时,不知道具体应该使用哪个函数。本课程通过大量的具体案例帮助学习快速掌握每个函数的应用场景,快速掌握OpenCV的核心使用方法和技巧。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值