OpenCV图像形态学详解

文章目录

一、什么是图像形态学?

图像形态学(Image Morphology)是数字图像处理领域的一个重要分支,主要研究基于形状的图像处理技术。它最初源于对生物体形态的研究,后来被引入到图像分析中,成为提取图像中有用形状特征的有效工具。

在OpenCV中,形态学操作主要基于二值图像(黑白图像)进行处理,通过结构元素(kernel)与图像进行特定操作来实现各种效果,广泛应用于边缘检测、噪声去除、形状分析等领域。

二、基本概念:结构元素

结构元素(Structuring Element)是形态学操作的核心,它决定了操作的邻域形状和大小。可以把它想象成一个小的矩阵或模板,在图像上滑动并进行比较。

python 复制代码
import cv2
import numpy as np

# 创建矩形结构元素
kernel_rect = cv2.getStructuringElement(cv2.MORPH_RECT, (5,5))
# 创建椭圆形结构元素
kernel_ellipse = cv2.getStructuringElement(cv2.MORPH_ELLIPSE, (5,5))
# 创建十字形结构元素
kernel_cross = cv2.getStructuringElement(cv2.MORPH_CROSS, (5,5))

print("矩形结构元素:\n", kernel_rect)
print("椭圆形结构元素:\n", kernel_ellipse)
print("十字形结构元素:\n", kernel_cross)

三、基本形态学操作

1. 腐蚀(Erosion)

腐蚀操作可以看作是将图像"收缩"或"细化"的过程。它会侵蚀掉物体的边界,使物体变小。

原理:结构元素在图像上滑动,只有当结构元素完全覆盖前景像素时,中心像素才保留为前景,否则变为背景

  • 图像腐蚀, 函数为:
python 复制代码
cv2.erode(src, kernel, dst,anchor,iterations,borderType,borderValue)
src: 输入的图像
kernel: 用于腐蚀的结构元件如果element = Mat(),则使用3 × 3的矩形结构单元。
dst: 它是与src相同大小和类型的输出图像。
iterations:腐蚀操作的迭代次数,默认为1。次数越多, 腐蚀操作执行的次数越多,腐蚀效果越明显

下面我们以一张太阳的图片来进行腐蚀:

python 复制代码
import cv2
import numpy as  np
sun = cv2.imread('sun.png')
cv2.imshow('src',sun)
cv2.waitKey(0)
kernel = np.ones((3,3),np.uint8) #设置kernel大小
erosion_1 = cv2.erode(sun,kernel,iterations=2)
cv2.imshow('erosion_1',erosion_1)
cv2.waitKey(0)

左图是原图,右边为腐蚀后的图片:

应用场景

  • 去除小的白噪声
  • 分离相连的物体
  • 消除细小的突出物

2. 膨胀(Dilation)

膨胀是腐蚀的对偶操作,可以看作是将图像"扩张"或"变粗"的过程。

原理:结构元素在图像上滑动,只要结构元素与前景像素有重叠,中心像素就设置为前景。

  • 图像腐蚀, 函数为:
python 复制代码
cv2.dilate(img, kernel, iteration)
参数含义:
img -- 目标图片
kernel -- 进行操作的内核,默认为3×3的矩阵
iterations -- 膨胀次数,默认为1
python 复制代码
# 膨胀操作
dilated = cv2.dilate(binary, kernel_rect, iterations=1)

cv2.imshow('Original', binary)
cv2.imshow('Dilated', dilated)
cv2.waitKey(0)
cv2.destroyAllWindows()

左图是原图,右边为膨胀后的图片:

应用场景

  • 填补物体中的空洞
  • 连接相邻的物体
  • 增加物体尺寸

3. 开运算(Opening)

开运算是先腐蚀后膨胀的过程。

作用:平滑物体的轮廓、断开较窄的狭颈并消除细的突出物。

下面以一张指纹图片,进行开运算操作

python 复制代码
import cv2
import numpy as  np
zhiwen = cv2.imread('zhiwen.png')
cv2.imshow('src2',zhiwen)
cv2.waitKey(0)
kernel = np.ones((2,2),np.uint8)
zhiwen_new = cv2.morphologyEx(zhiwen,cv2.MORPH_OPEN,kernel)
cv2.imshow('zhiwen_new',zhiwen_new)
cv2.waitKey(0)
  • 运行结果如下:

特点

  • 消除小的前景区域(噪声)
  • 平滑物体轮廓但不明显改变面积
  • 断开狭窄的连接

4. 闭运算(Closing)

闭运算是先膨胀后腐蚀的过程。

作用:弥合较窄的间断和细长的沟壑,清除小的孔洞,填补轮廓线中的断裂

python 复制代码
zhiwen = cv2.imread('zhiwen_duan.png')
cv2.imshow('src3',zhiwen)
cv2.waitKey(0)
kernel = np.ones((5,5),np.uint8)
zhiwen_new = cv2.morphologyEx(zhiwen,cv2.MORPH_CLOSE,kernel)
cv2.imshow('zhiwen_new1',zhiwen_new)
cv2.waitKey(0)
  • 运行结果如下:

    特点
  • 填补前景区域中的小孔
  • 连接邻近物体
  • 平滑轮廓但不明显改变面积

四、高级形态学操作

1. 形态学梯度

形态学梯度是膨胀图与腐蚀图之差,可以得到物体的轮廓。

作用:突出显示图像中强度变化剧烈的地方

python 复制代码
import cv2
import numpy as  np
wenzi = cv2.imread('wenzi.png')
cv2.imshow('wenzi_new',wenzi)
cv2.waitKey(0)
kernel = np.ones((2,2),np.uint8)
#膨胀-腐蚀
bianyuan = cv2.morphologyEx(wenzi,cv2.MORPH_GRADIENT,kernel)
cv2.imshow('bianyuan',bianyuan)
cv2.waitKey(0)
cv2.destroyAllWindows()
  • 运行结果如下:

应用:边缘检测、轮廓提取

2. 顶帽(Top Hat)与黑帽(Black Hat)

顶帽是原图像与开运算结果之差,黑帽是闭运算结果与原图像之差。

python 复制代码
import cv2
import numpy as  np
# # 顶帽 = 原始图像 - 开运算结果(先腐蚀后膨胀)
# # 黑帽 = 闭运算(先膨胀后腐蚀) - 原始图像
sun = cv2.imread('sun.png')
cv2.imshow('sun_yuantu',sun)
cv2.waitKey(0)
kernel = np.ones((2,2),np.uint8)

#顶帽
tophat = cv2.morphologyEx(sun,cv2.MORPH_TOPHAT,kernel)
cv2.imshow('TOPHAT',tophat)
cv2.waitKey(0)

#黑帽
blackhat = cv2.morphologyEx(sun,cv2.MORPH_BLACKHAT,kernel)
cv2.imshow('BLACKHAT',blackhat)
cv2.waitKey(0)
  • 运行结果如下

应用

  • 顶帽:突出比邻近区域亮的微小物体
  • 黑帽:突出比邻近区域暗的微小物体

五、总结

OpenCV中的形态学操作是图像处理中极为强大的工具,通过合理组合基本操作可以解决许多实际问题。关键点包括:

  1. 理解结构元素对结果的影响
  2. 掌握腐蚀、膨胀、开运算、闭运算等基本操作
  3. 学会根据实际问题选择适当的操作组合
  4. 通过调整迭代次数和结构元素大小优化效果

形态学操作虽然简单,但在实际应用中往往能发挥意想不到的效果,大家一定要多去练习并且在这些运行结果种发现各个操作的区别。
代码的学习就是多练,多看,多思考,相信大家坚持下去一定会成功的,希望这篇文章能帮助到您!

相关推荐
Ronin-Lotus2 分钟前
深度学习篇---Yolov系列
人工智能·深度学习
静心问道30 分钟前
GoT:超越思维链:语言模型中的有效思维图推理
人工智能·计算机视觉·语言模型
aneasystone本尊40 分钟前
学习 Claude Code 的工具使用(三)
人工智能
szxinmai主板定制专家42 分钟前
【精密测量】基于ARM+FPGA的多路光栅信号采集方案
服务器·arm开发·人工智能·嵌入式硬件·fpga开发
T__TIII1 小时前
Dify 自定义插件
人工智能·github
快起来别睡了1 小时前
LangChain 介绍及使用指南:从“会聊天”到“能干活”的 AI 应用开发工具
人工智能
AI数据皮皮侠1 小时前
中国区域10m空间分辨率楼高数据集(全国/分省/分市/免费数据)
大数据·人工智能·机器学习·分类·业界资讯
静心问道2 小时前
大语言模型能够理解并可以通过情绪刺激进行增强
人工智能·语言模型·大模型
运器1232 小时前
【一起来学AI大模型】算法核心:数组/哈希表/树/排序/动态规划(LeetCode精练)
开发语言·人工智能·python·算法·ai·散列表·ai编程
aneasystone本尊2 小时前
管理 Claude Code 的工具权限
人工智能