开运算和闭运算_形态学上的图像顶帽运算和黑帽运算是什么?

2a182cfe2091362525d830cbe95dabea.gif

ff4a22427619f306c72ec4b1839bd8cb.png

作者 | 杨秀璋 责编 | 夕颜 出品 | CSDN博客

数学形态学(Mathematical morphology)是一门建立在格论和拓扑学基础之上的图像分析学科,是数学形态学图像处理的基本理论。其基本的运算包括:腐蚀和膨胀、开运算和闭运算、骨架抽取、极限腐蚀、击中击不中变换、形态学梯度、Top-hat变换、颗粒分析、流域变换等。

本篇文章主要讲解Python调用OpenCV实现图像形态学转化,包括图像顶帽运算和图像黑帽运算,基础性知识希望对您有所帮助。

1.图像顶帽运算
2.图像黑帽运算

d30e8cec53f4f59f8dea60ca6de087a4.png

图像顶帽运算

1.基本原理


图像顶帽(或图像礼帽)运算是原始图像减去图像开运算的结果,得到图像的噪声。如下图所示:

顶帽运算(img) = 原始图像(img) - 开运算(img) 99296daf8310df494befe98ef214d09a.png

2.函数原型


图像开运算主要使用的函数morphologyEx,它是形态学扩展的一组函数,其参数cv2.MORPH_TOPHAT对应开运算。其原型如下:

dst = cv2.morphologyEx(src, cv2.MORPH_TOPHAT, kernel)

参数dst表示处理的结果,src表示原图像,cv2.MORPH_TOPHAT表示顶帽运算,kernel表示卷积核。下图表示5*5的卷积核,可以采用函数 np.ones((5,5), np.uint8) 构建。

7ba53550f7754ebb5a2bc4e3fbe0a733.png

卷积如下图所示:

1f56a5508ce8916fdc349bedfb00165c.png

3.代码实现


完整代码如下所示:

#encoding:utf-8import cv2import numpy as np#读取图片src = cv2.imread('test01.png', cv2.IMREAD_UNCHANGED)#设置卷积核kernel = np.ones((5,5), np.uint8)#图像顶帽运算result = cv2.morphologyEx(src, cv2.MORPH_TOPHAT, kernel)#显示图像cv2.imshow("src", src)cv2.imshow("result", result)#等待显示cv2.waitKey(0)cv2.destroyAllWindows()
输出结果如下图所示,可以看到外部噪声被提取出来。 f8a752ad405a42c46cf74129e3f206c6.png 如果想获取更多的细节,可以将卷积设置为10*10,如下图所示: kernel = np.ones((10,10), np.uint8)
result = cv2.morphologyEx(src, cv2.MORPH_TOPHAT, kernel) be9f93e348b579e63bebb52f74531230.png

7c6f51113d653a9110e3d3a5b66341e2.png

图像黑帽运算 1.基本原理
图像黑帽运算是图像闭运算操作减去原始图像的结果,得到图像内部的小孔,或者前景色中的小黑点。如下图所示: 黑帽运算(img) = 闭运算图像(img) - 原始图像(img)  24d3dd210dc818c2b8ab97bdd9f3032b.png 2.函数原型
图像开运算主要使用的函数morphologyEx,它是形态学扩展的一组函数,其参数cv2.MORPH_BLACKHAT对应开运算。其原型如下: dst = cv2.morphologyEx(src, cv2.MORPH_BLACKHAT, kernel) 参数dst表示处理的结果,src表示原图像,cv2.MORPH_BLACKHAT表示黑帽运算,kernel表示卷积核。下图表示5*5的卷积核,可以采用函数 np.ones((5,5), np.uint8) 构建。 c53de1740720f8e535065fc3c51c8a17.png 3.代码实现
完整代码如下所示:
#encoding:utf-8import cv2import numpy as np#读取图片src = cv2.imread('test02.png', cv2.IMREAD_UNCHANGED)#设置卷积核kernel = np.ones((5,5), np.uint8)#图像黑帽运算result = cv2.morphologyEx(src, cv2.MORPH_BLACKHAT, kernel)#显示图像cv2.imshow("src", src)cv2.imshow("result", result)#等待显示cv2.waitKey(0)cv2.destroyAllWindows()
输出结果如下图所示,可以看到图像内部黑点被提取出来。 895bf8578ed459347106b9ac4f9a14db.png 但内部比较大的四个黑点没有被提取,如果想获取更多的细节,可以将卷积设置为10*10,如下图所示:
kernel = np.ones((10,10), np.uint8)
result = cv2.morphologyEx(src, cv2.MORPH_BLACKHAT, kernel) 9826cbad4a7ce260ffac752b300a84fe.png 原文链接:https://0x9.me/vC3mK

2d9c207f65f038ef640f8baebfd6c610.png

053560b72a32491df1e88a132a4e316c.png

更多精彩推荐

☞遭遇 XSS 跨站脚本攻击?稳住,这些方法可保你渡劫 | 附代码、图解☞融资 2000 万美元后,他竟将核心代码全开源,这……能行吗?☞赞!网红程序员 AI 修复多国古老街景视频☞赠书 | 人工智能识万物:卷积神经网络的前世今生☞MySQL 索引分析除了 EXPLAIN 还有什么方法?☞医疗数字化:区块链或成最强辅助点分享点点赞点在看
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值