图像形态学

在图像处理中,形态学(Morphology) 是一种基于图像中物体形状的处理方法,通常用于二值图像和灰度图像。它通过腐蚀、膨胀等基本操作,结合开运算、闭运算、梯度运算、顶帽、黑帽等派生操作,来实现去噪、边缘检测、连接或断开物体等目的。

在 OpenCV 中,常用函数有:

  • cv2.erode() —— 腐蚀

  • cv2.dilate() —— 膨胀

  • cv2.morphologyEx() —— 各类高级形态学操作(开运算、闭运算、梯度、顶帽、黑帽)

准备图片:

sun.png

wenzi.png

zhiwen.png

zhiwen_duan.png


1. 图像腐蚀(Erosion)

原理

腐蚀操作的本质是:取局部最小值
在二值图像中,腐蚀会“侵蚀”白色区域(前景),使得物体的边界缩小,细小的高亮噪点被去除。

公式:

即:结构元素 B 在图像 A 上滑动,若完全落在前景内,则该像素保留,否则被侵蚀。

OpenCV 函数

cv2.erode(src, kernel, dst, anchor, iterations, borderType, borderValue)
  • src:输入图像

  • kernel:卷积核(结构元素),默认为 3×3 矩形

  • iterations:迭代次数,越大腐蚀越明显

参数名默认值类型 / 取值作用说明
src必填图像对象输入图像,可以是二值图、灰度图或彩色图。
kernelNone(默认 3×3 矩形)numpy.ndarray卷积核(结构元素),决定腐蚀范围和形状。
dstNone图像对象输出图像,和 src 类型、大小相同。通常不写,函数会返回结果。
anchor(-1,-1)(核中心)(x,y) 坐标核的参考点位置。默认在中心。
iterations1整数腐蚀迭代次数,数值越大,腐蚀越严重。
borderTypecv2.BORDER_CONSTANTOpenCV 边界模式边界扩展方式。- BORDER_CONSTANT 常数填充- BORDER_REPLICATE 复制边缘- BORDER_REFLECT 镜像填充
borderValue0(黑色)数值borderType=BORDER_CONSTANT 时使用,表示填充颜色。

代码示例

import cv2
import numpy as npsun = cv2.imread('sun.png')
cv2.imshow('sun', sun)
cv2.waitKey(0)kernel = np.ones((3,3), np.uint8)  # 3×3核
erosion_1 = cv2.erode(sun, kernel, iterations=2)  # 腐蚀2次
cv2.imshow('sun_erode', erosion_1)
cv2.waitKey(0)

说明

  • 如果 kernel 改为 5×5,腐蚀会更明显。

  • 如果 iterations 改为 5,物体会被“蚕食”得更多。


2. 图像膨胀(Dilation)

原理

膨胀操作的本质是:取局部最大值
在二值图像中,膨胀会“扩张”白色区域,使得物体边界扩大,细小的黑洞被填充。

公式:

OpenCV 函数

cv2.dilate(img, kernel, iterations)
参数名默认值类型 / 取值作用说明
src必填图像对象输入图像,可以是二值图、灰度图或彩色图。
kernelNone(默认 3×3 矩形)numpy.ndarray卷积核(结构元素),决定膨胀范围和形状。
dstNone图像对象输出图像,和 src 类型、大小相同。通常不写,函数会返回结果。
anchor(-1,-1)(核中心)(x,y) 坐标核的参考点位置。默认在中心。
iterations1整数膨胀迭代次数,数值越大,膨胀越明显。
borderTypecv2.BORDER_CONSTANTOpenCV 边界模式边界扩展方式。- BORDER_CONSTANT 常数填充- BORDER_REPLICATE 复制边缘- BORDER_REFLECT 镜像填充
borderValue0(黑色)数值borderType=BORDER_CONSTANT 时使用,表示填充颜色。

代码示例

wenzi = cv2.imread('wenzi.png')
cv2.imshow('wenzi', wenzi)
cv2.waitKey(0)kernel = np.ones((2,2), np.uint8)
wenzi_new = cv2.dilate(wenzi, kernel, iterations=2)
cv2.imshow('wenzi_dilate', wenzi_new)
cv2.waitKey(0)
cv2.destroyAllWindows()

说明

  • kernel 越大,膨胀效果越明显。

  • 常用于加粗文字、填补小空洞。


morphologyEx函数

cv2.morphologyEx(src, op, kernel[, dst[, anchor[, iterations[, borderType[, borderValue]]]]]) -> dst
参数名默认值类型 / 取值作用说明
src必填图像对象输入图像,可以是二值、灰度或彩色图。
op必填整数常量指定形态学操作类型(见下表)。
kernelNone(默认 3×3 矩形)numpy.ndarray卷积核(结构元素),决定操作范围和形状。
dstNone图像对象输出图像,与 src 类型、大小相同。通常不写,函数会返回结果。
anchor(-1,-1)(核中心)(x,y) 坐标核的参考点位置。默认在中心。
iterations1整数操作迭代次数,数值越大效果越强。
borderTypecv2.BORDER_CONSTANTOpenCV 边界模式边界扩展方式。
borderValue0(黑色)数值borderType=BORDER_CONSTANT 时使用,表示填充值。

3. 开运算与闭运算

(1)开运算(Opening)

先腐蚀后膨胀

  • 作用:去除小噪点、分离粘连物体。

kernel = np.ones((2,2), np.uint8)
zhiwen = cv2.imread('zhiwen.png')
zhiwen_new = cv2.morphologyEx(zhiwen, cv2.MORPH_OPEN, kernel)
cv2.imshow('zhiwen_OPEN', zhiwen_new)

(2)闭运算(Closing)

先膨胀后腐蚀

  • 作用:填补小黑洞、连接相邻物体。(指纹断点被连接)

kernel = np.ones((4,4), np.uint8)
zhiwen_duan = cv2.imread('zhiwen_duan.png')
zhiwen_new = cv2.morphologyEx(zhiwen_duan, cv2.MORPH_CLOSE, kernel)
cv2.imshow('zhiwen_duan_CLOSE', zhiwen_new)


4. 形态学梯度(Gradient)

原理

梯度 = 膨胀 - 腐蚀
它突出显示物体的边缘区域,常用于边缘检测。

代码示例

wenzi = cv2.imread('wenzi.png', 0)
cv2.imshow('wenzi', wenzi)
cv2.waitKey(0)kernel = np.ones((2, 2), np.uint8)  # 设置kernel大小
# 膨胀
pz_wenzi = cv2.dilate(wenzi, kernel, iterations=1)
cv2.imshow('wenzi_dilate', pz_wenzi)
cv2.waitKey(0)# 腐蚀
fs_wenzi = cv2.erode(wenzi, kernel, iterations=1)
cv2.imshow('wenzi_erode', fs_wenzi)
cv2.waitKey(0)# 膨胀 - 腐蚀
bianyuan = cv2.morphologyEx(wenzi, cv2.MORPH_GRADIENT, kernel)
cv2.imshow('wenzi_GRADIENT', bianyuan)
cv2.waitKey(0)
cv2.destroyAllWindows()

以下三张图为:原图膨胀后;原图腐蚀后;原图梯度后


5. 顶帽与黑帽运算

(1)顶帽(Top Hat)

顶帽 = 原始图像 - 开运算结果

  • 突出图像中比周围亮的部分(亮斑检测)。

(2)黑帽(Black Hat)

黑帽 = 闭运算结果 - 原始图像

  • 突出图像中比周围暗的部分(暗斑检测)。

代码示例

sun = cv2.imread('sun.png', 0)
cv2.imshow('sun', sun)
cv2.waitKey(0)kernel = np.ones((2, 2), np.uint8)  # 设置kernel大小
# 开运算
open_sun = cv2.morphologyEx(sun, cv2.MORPH_OPEN, kernel)
cv2.imshow('sun_OPEN', open_sun)
cv2.waitKey(0)# 顶帽运算
tophat = cv2.morphologyEx(sun, cv2.MORPH_TOPHAT, kernel)
cv2.imshow('sun_TOPHAT', tophat)
cv2.waitKey(0)# 闭运算
close_sun = cv2.morphologyEx(sun, cv2.MORPH_CLOSE, kernel)
cv2.imshow('sun_CLOSE', close_sun)
cv2.waitKey(0)# 黑帽运算
blackhat = cv2.morphologyEx(sun, cv2.MORPH_BLACKHAT, kernel)
cv2.imshow('sun_BLACKHAT', blackhat)
cv2.waitKey(0)
cv2.destroyAllWindows()

以下图片为:开运算、顶帽、闭运算、黑帽


总结

  • 腐蚀:缩小白色区域,去噪点。

  • 膨胀:扩大白色区域,填洞。

  • 开运算:去噪、断开。

  • 闭运算:填洞、连接。

  • 梯度:提取边缘。

  • 顶帽:突出亮斑。

  • 黑帽:突出暗斑。

形态学操作广泛应用于:

  • 图像预处理(去噪、增强特征)

  • OCR 文字识别(加粗或断开笔画)

  • 工业检测(焊点检测、缺陷检测)

  • 医学图像处理(血管提取)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/94302.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/94302.shtml
英文地址,请注明出处:http://en.pswp.cn/bicheng/94302.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

学习嵌入式第三十五天

文章目录网络(续上)1.函数接口2.相关功能实现1.TCP连接2.UDP习题网络(续上) 1.函数接口 sendto 原型:ssize_t sendto(int sockfd, const void *buf, size_t len, int flags,const struct sockaddr *dest_addr, sockle…

为什么给数据表加了索引,写入速度反而变慢了

为数据表增加索引后之所以会导致写入(包括插入、更新、删除)操作的速度变慢,其根本原因在于索引本质上是一个独立的、需要与主表数据保持实时同步的“数据结构”。这一机制的核心逻辑涵盖五个方面:因为索引本质上是一个“独立的数…

.NET Core 中采用独立数据库的SAAS(多租户)方法

介绍多租户是指一种软件架构,其中软件的单个实例在服务器上运行并为多个租户提供服务。在基于 SAAS 的平台中,租户是指使用该平台开展业务运营的客户。每个租户都拥有独立的数据、用户帐户和配置设置,并且与其他租户隔离。多租户允许有效利用…

运维日常工作100条

这是一份非常详细和实用的“运维日常工作100条”清单。它涵盖了从日常巡检、变更管理、故障处理到安全、优化和文档等运维工作的方方面面,可以作为运维工程师的日常工作指南和检查清单。 运维日常工作100条 一、日常巡检与监控 (20条) 检查核心监控大盘:查看整体业务健康状态…

OpenHarmony子系统介绍

OpenHarmony子系统OpenHarmony子系统1. AI业务子系统2. 方舟运行时子系统3. ArkUI框架子系统4. DFX子系统5. DeviceProfile子系统6. XTS子系统7. 上传下载子系统8. 主题框架子系统9. 事件通知子系统10. 位置服务子系统11. 元能力子系统12. 全局资源调度子系统13. 全球化子系统1…

博士招生 | 英国谢菲尔德大学 招收计算机博士

内容源自“图灵学术博研社”gongzhonghao学校简介谢菲尔德大学(The University of Sheffield)是英国久负盛名的公立研究型大学,也是罗素集团成员之一。在 2026 年 QS 世界大学排名中,谢菲尔德大学位列第92位,其中计算机…

如何理解面向过程和面向对象,举例说明一下?

面向过程和面向对象是两种不同的编程思想,核心区别在于解决问题的视角不同:前者关注 “步骤和过程”,后者关注 “对象和交互”。面向过程的核心思想是把问题拆解成一系列步骤,通过函数实现每个步骤,然后按顺序调用这些…

深入了解评估与微调中使用的Graders:原理、实现与最佳实践

深入了解评估与微调中使用的Graders 在模型评估与微调(Fine-tuning)过程中,Graders(评分器)是衡量模型输出与参考答案之间表现的重要工具。本文将系统介绍Grader的类型、技术实现及如何在实际项目中融入稳定且高质量的…

行缓存(line buffer)在图像卷积中的工作方式

上面这张图配合文字,展示了行缓存(line buffer)在图像卷积中的工作方式:上半部分是一个按行扫描输入的图像块(示例为 99,编号 1–81)。 蓝色表示已被写入行缓存并按队列等待的数据,绿…

【数据分享】中国371个城市的坡度矢量数据和excel数据

今天要说明数据就是中国371个城市的坡度矢量数据和excel数据。数据介绍在城市发展的进程中,地形地貌始终是影响规划决策的关键因素,而坡度作为表征地表倾斜程度的核心指标,更是贯穿于城市建设、生态保护等诸多环节。本文将全面解读中国 371 个…

《WINDOWS 环境下32位汇编语言程序设计》第7章 图形操作(1)

图形设备接口GDI(Graphics Device Interface)是Win32的一个重要组成部分,其作用是允许Windows的应用程序将图形输出到计算机屏幕、打印机或其他输出设备上。GDI实际上是一个函数库,包括直线、画图和字体处理等数百个函数。7.1 GDI…

数据结构-HashMap

在 Java 键值对(Key-Value)集合中,HashMap 是使用频率最高的实现类之一,凭借高效的查找、插入性能,成为日常开发的 “利器”。本文将从 HashMap 的底层原理、核心特点、常用方法到遍历方式、使用注意事项,进…

[系统架构设计师]安全架构设计理论与实践(十八)

[系统架构设计师]安全架构设计理论与实践(十八) 一.信息安全面临的威胁 1.信息系统安全威胁的来源 物理环境,通信链路,网络系统,操作系统,应用系统,管理系统 2.网络与信息安全风险类别 风险类别…

AI适老服务暖人心:AI适老机顶盒破数字鸿沟、毫米波雷达护独居安全,银发生活新保障

银发经济领域长期受限于 “专业照护资源稀缺”“老年人数字适应能力弱”“独居老人安全隐患多” 的困境,而 AI 技术的适老化改造,正让银发服务从 “被动保障” 转向 “主动关怀”,既能帮老年人跨越数字鸿沟,又能为独居老人筑起安全…

Linux应用软件编程---网络编程1(目的、网络协议、网络配置、UDP编程流程)

Linux下的网络编程一、目的不同主机,进程间通信。二、解决的问题1. 主机与主机之间物理层面必须互联互通。 2. 进程与进程在软件层面必须互联互通。物理层面的互联互通流程图如下:其中:IP地址:计算机的软件地址,用来标…

常见开源协议详解:哪些行为被允许?哪些被限制?

常见开源协议详解:哪些行为被允许?哪些被限制? 开源世界的魅力在于共享与合作,但不同的开源协议对分发、修改、再发布以及宣传/推广有不同的要求和限制。很多开发者在 fork 项目、改 README、放到自己仓库并在自媒体传播 时&…

服务器硬盘进行分区和挂载

查看服务器上的硬盘:lsblk -d -o NAME,SIZE,MODEL可以看到我的硬盘是除了vda系统盘以外,还有个vdb。我们查看一下分区:lsblk可以看到:vdb 1T disk (底下没有分区,也没有挂载)我们想要用起来这…

【C初阶】数据在内存中的存储

目录 1. 整数在内存中的存储 2. 大小端字节序 2.1 什么是大小端? 2.2 为什么有大小端? 2.3 练习 2.3.1 练习1 2.3.2 练习2 2.3.3 练习3 2.3.4 练习4 2.3.5 练习5 2.3.6 练习6 3. 浮点数在内存中的存储 3.1 浮点数存储的过程 3.2 浮点数的取…

AI 自动化编程 trae 体验2 帮我分析一个项目

总结: 接手一个项目可以让trae 帮忙分析 上次讲到trae在处理组件引入的时候,经常会碰到版本问题,分析引入了互联网上非本版本或者有bug的代码。主要依赖互联网的资源库。 但是分析一个项目应该是没问题。 这次表现非常好,接手一个…

VMware虚拟机中CentOS 7 报错 ping: www.xxx.com: Name or service not known

1:主要原因是网络配置的问题 2:其实就是下面三张图片中的,物理机虚拟网卡 vmware8 和虚拟机网络编辑器,如果设置静态IP 就是这三个地方的问题最简单的解决办法第一步:还原虚拟机网络点击确认后 ** 第二步给自己的虚拟机设置网络连接方式 选择NAT模式连接…