图像处理|膨胀操作

在图像处理领域,形态学操作是一种基于图像形状的操作,用于分析和处理图像中对象的几何结构。**膨胀操作(Dilation)**是形态学操作的一种,它能够扩展图像中白色区域(前景)或减少黑色区域(背景),在图像增强、噪声去除和对象连接中发挥着重要作用。

本文将详细介绍膨胀操作的概念、原理、实现方法以及应用场景,并通过代码示例帮助大家更直观地理解。


1. 什么是膨胀操作?

膨胀操作的核心思想是通过特定的结构元素(Kernel),对图像的前景(通常是白色区域)进行扩展,使得图像中的前景对象变得更大。

原理

  • 对于二值图像,膨胀操作会将前景像素(通常是白色,值为1)周围的背景像素(通常是黑色,值为0)变成前景像素。
  • 膨胀操作以卷积核为中心,将该区域内的像素值进行“最大化”,因此白色区域会向外扩展。

2. 膨胀操作的作用

  1. 填充空洞:可以填补目标对象内部或边缘的细小黑色区域。
  2. 增强连接:将分离的白色区域连接在一起。
  3. 扩大目标:扩展目标区域,用于增强视觉效果或特定分析需求。
  4. 去除噪声:对于小型黑色噪声点,膨胀操作可以将其覆盖。

3. 实现膨胀操作

我们可以使用 OpenCV 库轻松实现膨胀操作。以下是膨胀操作的核心方法:

cv2.dilate(src, kernel, iterations)

参数解释:

  • src:输入图像,通常为二值图像。
  • kernel:结构元素,定义膨胀的形状和大小。
  • iterations:膨胀的次数,默认为1。

4. 膨胀操作的代码实现

下面通过一个具体示例演示如何使用 OpenCV 实现膨胀操作。

原图

我们选用以下二值图像作为示例:

  • 白色区域表示前景(目标)。
  • 黑色区域表示背景。

代码示例

import cv2
import numpy as np
from matplotlib import pyplot as plt

# 创建一个简单的二值图像
img = np.zeros((200, 200), dtype=np.uint8)
cv2.rectangle(img, (50, 50), (150, 150), 255, -1)  # 在图像中心画一个白色矩形

# 定义结构元素(kernel)
kernel = cv2.getStructuringElement(cv2.MORPH_RECT, (5, 5))

# 应用膨胀操作
dilated_img = cv2.dilate(img, kernel, iterations=3)

# 显示原图和膨胀后的图像
plt.figure(figsize=(10, 5))
plt.subplot(1, 2, 1)
plt.title("Original Image")
plt.imshow(img, cmap='gray')
plt.axis('off')

plt.subplot(1, 2, 2)
plt.title("Dilated Image")
plt.imshow(dilated_img, cmap='gray')
plt.axis('off')

plt.tight_layout()
plt.show()

运行结果

  1. 原始图像:一个中心白色矩形。
  2. 膨胀后图像:白色区域被扩展,矩形边界向外扩展了几个像素。

5. 不同结构元素的影响

膨胀操作的效果与所选的结构元素密切相关。OpenCV 提供了三种常用结构元素:

  1. 矩形(cv2.MORPH_RECT)
    结构元素形状为矩形,适用于一般场景。

  2. 椭圆(cv2.MORPH_ELLIPSE)
    结构元素形状为椭圆,适合处理圆形或椭圆形目标。

  3. 十字形(cv2.MORPH_CROSS)
    结构元素形状为十字,主要用于保留十字形细节。

代码示例

import cv2
import numpy as np
import matplotlib.pyplot as plt

img = np.zeros((200, 200), dtype=np.uint8)
cv2.rectangle(img, (50, 50), (150, 150), 255, -1)  # 在图像中心画一个白色矩形

# 不同形状的结构元素
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))

# 使用不同的结构元素进行膨胀
dilated_rect = cv2.dilate(img, kernel_rect)
dilated_ellipse = cv2.dilate(img, kernel_ellipse)
dilated_cross = cv2.dilate(img, kernel_cross)

# 显示结果
titles = ['Original', 'Rect Kernel', 'Ellipse Kernel', 'Cross Kernel']
images = [img, dilated_rect, dilated_ellipse, dilated_cross]

plt.figure(figsize=(15, 5))
for i in range(4):
    plt.subplot(1, 4, i + 1)
    plt.title(titles[i])
    plt.imshow(images[i], cmap='gray')
    plt.axis('off')
plt.tight_layout()
plt.show()


6. 膨胀操作的应用场景

  1. 图像分割
    在图像分割中,膨胀操作常用于连接分割区域或消除小孔洞。

  2. 噪声去除
    在预处理阶段,膨胀可以用来增强前景或消除小面积噪声点。

  3. 边缘检测
    膨胀操作与腐蚀操作结合使用,可以提取目标边缘。

  4. 字符识别
    在 OCR(光学字符识别)中,膨胀可以帮助连接字符断点,改善识别结果。


7. 总结

膨胀操作是形态学操作中的一种基础操作,通过扩展前景区域实现图像增强。本文从概念到代码实现,再到实际应用,对膨胀操作进行了全面解析。

核心要点

  1. 膨胀操作通过结构元素扩展前景区域。
  2. 不同形状和大小的结构元素对膨胀效果有显著影响。
  3. 膨胀操作在图像分割、去噪和边缘检测等领域有广泛应用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/952676.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

汉图科技XP356DNL高速激光打印一体机综合性能测评

汉图科技XP356DNL高速激光打印一体机效率方面表现出色,支持A4纸型的高速打印,单面打印速度高达35页/分钟,自动双面打印速度可达32面/分钟,这样的速度在日常办公中能够极大地提高打印效率,减少等待时间,满足…

Unity + Firebase + GoogleSignIn 导入问题

我目前使用 Unity版本:2021.3.33f1 JDK版本为:1.8 Gradle 版本为:6.1.1 Firebase 版本: 9.6.0 Google Sign In 版本为: 1.0.1 问题1 :手机点击登录报错 apk转化成zip,解压,看到/lib/armeabi-v…

如何搭建 Vue.js 开源项目的 CI/CD 流水线

网罗开发 (小红书、快手、视频号同名) 大家好,我是 展菲,目前在上市企业从事人工智能项目研发管理工作,平时热衷于分享各种编程领域的软硬技能知识以及前沿技术,包括iOS、前端、Harmony OS、Java、Python等…

Elasticsarch:使用全文搜索在 ES|QL 中进行过滤 - 8.17

8.17 在 ES|QL 中引入了 match 和 qstr 函数,可用于执行全文过滤。本文介绍了它们的作用、使用方法、与现有文本过滤方法的区别、当前的限制以及未来的改进。 ES|QL 现在包含全文函数,可用于使用文本查询过滤数据。我们将回顾可用的文本过滤方法&#xf…

ISP流程--去马赛克详解

前言 本期我们将深入讨论ISP流程中的去马赛克处理。我们熟知,彩色图像由一个个像元组成,每个像元又由红、绿、蓝(RGB)三通道构成。而相机传感器只能感知光的强度,无法直接感知光谱信息,即只有亮暗而没有颜色…

晨辉面试抽签和评分管理系统之七:面试成绩核算的三种方式

晨辉面试抽签和评分管理系统(下载地址:www.chenhuisoft.cn)是公务员招录面试、教师资格考试面试、企业招录面试等各类面试通用的考生编排、考生入场抽签、候考室倒计时管理、面试考官抽签、面试评分记录和成绩核算的面试全流程信息化管理软件。提供了考生…

FastApi Swagger 序列化问题

问题 错误现象: fastapi的 swagger 界面无法正常打开控制台报错:raise PydanticInvalidForJsonSchema(fCannot generate a JsonSchema for {error_info}) 详细报错: File "d:\Envs\miniconda3\envs\xdagent\lib\site-packages\pydan…

Browser-Use Web UI:浏览器自动化与AI的完美结合

Browser-Use Web UI:浏览器自动化与AI的完美结合 前言简介一、克隆项目二、安装与环境配置1. Python版本要求2. 安装依赖3. 安装 Playwright4. 配置环境变量(非必要步骤)三、启动 WebUI四、配置1. Agent设置2. 大模型设置3. 浏览器相关设置4. 运行 Agent结语前言 Web UI是在…

秒懂虚拟化(三):桌面拟化、用户体验虚拟化、应用程序虚拟化全解析,通俗解读版

秒懂虚拟化(二):服务器虚拟化、操作系统虚拟化、服务虚拟化全解析,通俗解读版-CSDN博客这篇文章学习了服务器虚拟化、操作系统虚拟化、服务器虚拟化,本节将继续学习桌面虚拟化、用户体验虚拟化、应用程序虚拟化。 1、…

UVM RAL Register Abstraction Layer:寄存器抽象层

topic 没有RAL的TB 有RAL的TB RAL介绍 summary

扬帆数据结构算法之舟,启航C++探索征途——LeetCode深度磨砺:顺序表技术精进实践

人无完人,持之以恒,方能见真我!!! 共同进步!! 文章目录 顺序表练习1.移除数组中指定的元素方法1(顺序表)方法2(双指针) 2.删除有序数组中的重复项…

【Linux网络编程】网络层 | IP协议 | 网段划分 | 私有IP和公有IP | NAT技术

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站 🌈个人主页: 南桥几晴秋 🌈C专栏: 南桥谈C 🌈C语言专栏: C语言学习系…

Web基础之什么是HTTP协议

Q:什么是HTTP协议? 概念:Hyper Text Transfer Protocol,超文本传输协议,规定了浏览器和服务器之间数据传输的规则。 特点: 1.基于TCP协议:面向连接,安全 2.基…

小米路由器IPv6 功能使用指南

本文不限于多层路由使用IPv6 的情况,提供解决IPv6 无法获取的更硬核的方法,需要有ssh 工具。(无安卓设备,测试环境win、mac、ios) 首先明确一点,就是如果想让你的设备得到GUA 地址,即访问 6.i…

element plus 使用 upload 组件达到上传数量限制时隐藏上传按钮

最近在重构项目,使用了 element plus UI框架,有个功能是实现图片上传,且限制只能上传一张图片,结果,发现,可以限制只上传一张图片,但是上传按钮还在,如图: 解决办法&…

汽车基础软件AutoSAR自学攻略(三)-AutoSAR CP分层架构(2)

汽车基础软件AutoSAR自学攻略(三)-AutoSAR CP分层架构(2) 下面我们继续来介绍AutoSAR CP分层架构,下面的文字和图来自AutoSAR官网目前最新的标准R24-11的分层架构手册。该手册详细讲解了AutoSAR分层架构的设计,下面让我们来一起学习一下。 Introductio…

MBTiles 爬取,读取,数据转换,发布

MBTiles :https://github.com/mapbox/mbtiles-spec/blob/master/1.3/spec.md 1.MBTiles是什么 MBTiles是一个在SQLite 数据库存储瓦片地图数据的标准,该标准的目的是即时传输和使用数据。 作为一个容器格式,MBTiles可以存储任何瓦片数据,…

机器学习笔记合集

大家好,这里是好评笔记,公主 号:Goodnote。本笔记的任务是解读机器学习实践/面试过程中可能会用到的知识点,内容通俗易懂,入门、实习和校招轻松搞定。 笔记介绍 本笔记的任务是解读机器学习实践/面试过程中可能会用到…

java_将数据存入elasticsearch进行高效搜索

使用技术简介: (1) 使用Nginx实现反向代理,使前端可以调用多个微服务 (2) 使用nacos将多个服务管理关联起来 (3) 将数据存入elasticsearch进行高效搜索 (4) 使用消息队列rabbitmq进行消息的传递 (5) 使用 openfeign 进行多个服务之间的api调用 参…

Gitlab-Runner配置

原理 Gitlab-Runner是一个非常强大的CI/CD工具。它可以帮助我们自动化执行各种任务,如构建、测试和部署等。Gitlab-Runner和Gitlab通过API通信,接收作业并提交到执行队列,Gitlab-Runner从队列中获取作业,并允许在不同环境下进行作…