OpenCV形态学运算中梯度运算、顶帽、黑帽运算讲解与实战应用(附Python源码)

简介: OpenCV形态学运算中梯度运算、顶帽、黑帽运算讲解与实战应用(附Python源码)

需要源码和图片请点赞关注收藏后评论区留言私信~~~

腐蚀和膨胀是形态学运算的基础操作,除了开运算和闭运算以外,形态学中还有几种比较有特点的运算,OpenCV提供了一个morphologyEx方法,包含所有常用的运算 语法如下

dst=cv2.morphologyEx(src,op,kernel,anchor,iterations,borderType,borderValue)

src 原始图像

op 操作类型 具体值如下表

kernel 操作过程中使用的核

anchor 核的锚点位置

形态学函数的操作类型参数

一、梯度运算

这里的梯度是指图像梯度,可以简单理解为像素的变化程度,如果几个连续的像素,其像素值跨度越大,则梯度值越大

梯度运算的运算过程如下图所示,让原图的膨胀图减原图的腐蚀图,因为膨胀图比原图大,腐蚀图比原图小,利用腐蚀图将膨胀图掏空,就得到了原图的轮廓图

下面通过代码实现这个效果

部分代码如下

import cv2
import numpy as np
img = cv2.imrespider.png")  # 读取原图
k = np.ones((5,5), np.uint8)  # 创建5*5的数组作为核
cv2.imshow("imgimg)  # 显示原图
dst = cv2.morphologyEx(img, cv2.MORPH_GRADIENT, k) # 进行梯度运算
cv2.imshow("dst", ds 显示梯度运算结果
cv2.waitKey()  # 按下任何键盘按键后
cv2.destroyAllWindows()  # 释放所有窗体

二、顶帽运算

顶帽运算的运算过程如下图所示,让原图减原图的开运算图,因为开运算抹除图像的外部细节,有外部细节的图像减去无外部细节的图像,得到的结果就只剩外部细节了,所以经过顶帽运算之后,小蜘蛛就只剩蜘蛛腿了

部分代码如下

import cv2
import numpy as np
img = cv2("spider.png")  # 读取原图
k = np.on((5, 5), np.uint8)  # 创建5*5的数组作为核
cv2.imshow("img", img)  # 显示原图
dst = cvmorphologyEx(img, cv2.MORPH_TOPHAT, k)  # 进行顶帽运算
cv2.imshow("t", dst)  # 显示顶帽运算结果
cv2.waitKey()  # 按下任何键盘按键后
cv2.destroyAllWind()  # 释放所有窗体

三、黑帽运算

黑猫运算的运算过程如下图所示,让原图的闭运算图减去原图,因为闭运算抹除图像的内部细节,无内部细节的图像减去有内部细节的图像,得到的结果就只剩内部细节了,所以经过黑帽运算之后,小蜘蛛就只剩下斑点、花纹和眼睛了

部分代码如下

import cv2
import numpy as np
img = cv2.imread("spider2.png")  # 读取原图
k = np.es((5, 5), np.uint8)  # 创建5*5的数组作为核
cv2.imsow("img", img)  # 显示原图
dst = c.(img, cv2.MORPH_BLACKHAT, k)  # 进行黑帽运算
cv2.imsh"dst", dst)  # 显示黑帽运算结果
cv2.waiey() 按下任何键盘按键后
cv2.destroyAllWindows()  # 释放所有窗体

创作不易 觉得有帮助请点赞关注收藏~~~

相关文章
|
5月前
|
SQL 关系型数据库 数据库
Python SQLAlchemy模块:从入门到实战的数据库操作指南
免费提供Python+PyCharm编程环境,结合SQLAlchemy ORM框架详解数据库开发。涵盖连接配置、模型定义、CRUD操作、事务控制及Alembic迁移工具,以电商订单系统为例,深入讲解高并发场景下的性能优化与最佳实践,助你高效构建数据驱动应用。
673 7
|
5月前
|
数据采集 Web App开发 数据安全/隐私保护
实战:Python爬虫如何模拟登录与维持会话状态
实战:Python爬虫如何模拟登录与维持会话状态
|
5月前
|
存储 数据采集 监控
Python文件操作全攻略:从基础到高级实战
本文系统讲解Python文件操作核心技巧,涵盖基础读写、指针控制、异常处理及大文件分块处理等实战场景。结合日志分析、CSV清洗等案例,助你高效掌握文本与二进制文件处理,提升程序健壮性与开发效率。(238字)
493 1
|
5月前
|
Java 调度 数据库
Python threading模块:多线程编程的实战指南
本文深入讲解Python多线程编程,涵盖threading模块的核心用法:线程创建、生命周期、同步机制(锁、信号量、条件变量)、线程通信(队列)、守护线程与线程池应用。结合实战案例,如多线程下载器,帮助开发者提升程序并发性能,适用于I/O密集型任务处理。
513 0
|
5月前
|
机器学习/深度学习 监控 数据挖掘
Python 高效清理 Excel 空白行列:从原理到实战
本文介绍如何使用Python的openpyxl库自动清理Excel中的空白行列。通过代码实现高效识别并删除无数据的行与列,解决文件臃肿、读取错误等问题,提升数据处理效率与准确性,适用于各类批量Excel清理任务。
562 0
|
6月前
|
数据采集 机器学习/深度学习 人工智能
Python:现代编程的首选语言
Python:现代编程的首选语言
818 102
|
6月前
|
数据采集 机器学习/深度学习 算法框架/工具
Python:现代编程的瑞士军刀
Python:现代编程的瑞士军刀
413 104
|
6月前
|
人工智能 自然语言处理 算法框架/工具
Python:现代编程的首选语言
Python:现代编程的首选语言
332 103
|
6月前
|
机器学习/深度学习 人工智能 数据挖掘
Python:现代编程的首选语言
Python:现代编程的首选语言
271 82

推荐镜像

更多