图像数据处理17

四、形态学图像处理

4.3 开运算与闭运算

4.3.1开运算与闭运算的定义:

开运算:先腐蚀,再膨胀

闭运算:先膨胀,再腐蚀

记忆方法: 膨胀(胀开)所以开运算最后对应的结果是膨胀,闭运算则与其相反,最后对应的结果是腐蚀。

4.3.2开运算与闭运算的作用:

开运算

以二值图像为例,若黑色背景上有一些白色小斑点噪声,开运算先通过腐蚀操作削弱前景图像(所有前景图像即所有白色的部分)来去除噪音(白色小斑点),因为噪音面积相对较小,执行完腐蚀操作后会被黑色完全覆盖。随后再通过开运算的膨胀操作增强前景图像的边界,恢复因腐蚀操作而受影响的非噪音部分的形状面积。其主要优点是不明显改变图像面积的情况下,消除细小的噪音。

闭运算

还是以二值图像为例,闭运算先通过膨胀操作来增强前景图像,通过对前景图像(白色部分)边界的扩充,来消除掺杂在其中的小黑点等噪音,随后在通过腐蚀操作其的腐蚀操作来削弱前景图像的边界,恢复其因膨胀操作而扩充的形状面积。

4.3.3实际应用

python 复制代码
import cv2
import numpy as np

# 读取图像
image = cv2.imread('taiyang2.jpg')

# 定义结构元素
kernel = np.ones((10, 10), np.uint8)

# 开运算:先腐蚀后膨胀
opening = cv2.morphologyEx(image, cv2.MORPH_OPEN, kernel)

# 闭运算:先膨胀后腐蚀
closing = cv2.morphologyEx(image, cv2.MORPH_CLOSE, kernel)

# 将图像缩小一半
resized_image = cv2.resize(image, (0, 0), fx=0.5, fy=0.5)
resized_opening = cv2.resize(opening, (0, 0), fx=0.5, fy=0.5)
resized_closing = cv2.resize(closing, (0, 0), fx=0.5, fy=0.5)

# 水平拼接图像
combined_image = np.hstack((resized_image, resized_opening, resized_closing))

# 在一个窗口中显示拼接后的图像
cv2.imshow('Combined Image', combined_image)

# 等待任意键盘按键
cv2.waitKey(0)
cv2.destroyAllWindows()

第一幅图像是原图,第二幅图像是开运算处理后的图像,第三幅图像是闭运算处理后的图像

在实际应用中开运算与闭运算往往是结合在一起用的,这样往往能达到更好的处理效果。

先开运算后闭运算

python 复制代码
import cv2
import numpy as np

# 读取图像
image = cv2.imread('taiyang2.jpg')

# 定义结构元素
kernel = np.ones((10, 10), np.uint8)

# 开运算:先腐蚀后膨胀
opening = cv2.morphologyEx(image, cv2.MORPH_OPEN, kernel)

# 对开运算后的图像进行闭运算
final_operation = cv2.morphologyEx(opening, cv2.MORPH_CLOSE, kernel)

# 将图像缩小一半
resized_image = cv2.resize(image, (0, 0), fx=0.5, fy=0.5)
resized_final = cv2.resize(final_operation, (0, 0), fx=0.5, fy=0.5)

# 水平拼接图像
combined_image = np.hstack((resized_image, resized_final))

# 在一个窗口中显示拼接后的图像
cv2.imshow('Combined Image', combined_image)

# 等待任意键盘按键
cv2.waitKey(0)
cv2.destroyAllWindows()

先闭运算后开运算

python 复制代码
import cv2
import numpy as np

# 读取图像
image = cv2.imread('taiyang2.jpg')

# 定义结构元素
kernel = np.ones((10, 10), np.uint8)

# 闭运算:先膨胀后腐蚀
closing = cv2.morphologyEx(image, cv2.MORPH_CLOSE, kernel)

# 对闭运算后的图像进行开运算
final_operation = cv2.morphologyEx(closing, cv2.MORPH_OPEN, kernel)

# 将图像缩小一半
resized_image = cv2.resize(image, (0, 0), fx=0.5, fy=0.5)
resized_final = cv2.resize(final_operation, (0, 0), fx=0.5, fy=0.5)

# 水平拼接图像
combined_image = np.hstack((resized_image, resized_final))

# 在一个窗口中显示拼接后的图像
cv2.imshow('Combined Image', combined_image)

# 等待任意键盘按键
cv2.waitKey(0)
cv2.destroyAllWindows()

注:本人为在校学生,博客是边学边写的,主要是为了巩固知识,如有错误请积极指正。

本文的内容主要基于我对张运楚教授编著的《数字图像处理》一书的学习和理解。这本书深入浅出地介绍了数字图像处理的基本理论以及经典算法等,并且提供了丰富的示例代码和实际用例,极大地帮助了我学习图像处理知识。在此,我推荐大家阅读这本书,更加深入的学习有关图像处理的知识。

相关推荐
wzf@robotics_notes4 分钟前
PCL PolygonMesh 与 TextureMesh 源码阅读与简单测试
图像处理·计算机视觉·机器人
king of code porter9 分钟前
深度学习之用CelebA_Spoof数据集搭建一个活体检测-训练好的模型用MNN来推理
人工智能·深度学习·mnn
yuhouxiyang23 分钟前
学习海康VisionMaster之直方图工具
学习·计算机视觉
明明跟你说过23 分钟前
掌握 LangChain 文档处理核心:Document Loaders 与 Text Splitters 全解析
人工智能·语言模型·自然语言处理·langchain
EasyDSS25 分钟前
嵌入式EasyRTC音视频实时通话SDK在工业制造领域的智能巡检/AR协作等应用
人工智能·音视频
正在走向自律34 分钟前
GpuGeek 网络加速:破解 AI 开发中的 “最后一公里” 瓶颈
网络·人工智能·python·机器学习·性能优化·gpugeek
正儿八经的数字经1 小时前
人工智能100问☞第24问:什么是生成对抗网络(GAN)?
人工智能·神经网络·生成对抗网络
wei_shuo2 小时前
GpuGeek 实操指南:So-VITS-SVC 语音合成与 Stable Diffusion 文生图双模型搭建,融合即梦 AI 的深度实践
人工智能·stable diffusion·gpu算力·gpuseek
x-cmd2 小时前
[250516] OpenAI 升级 ChatGPT:GPT-4.1 及 Mini 版上线!
人工智能·chatgpt·openai·gpt-4.1