当前位置: 首页 > news >正文

OpenCV自学笔记十一:形态学操作(一)

目录

1、腐蚀

2、膨胀

3、通用形态学函数

4、开运算

5、闭运算


1、腐蚀

腐蚀(Erosion)是数字图像处理中的一种形态学操作,用于消除图像中边界附近的细小区域或缩小对象的大小。腐蚀操作通过卷积输入图像与结构元素(也称为腐蚀核)来实现。

腐蚀操作可以用来消除图像中的细小噪声、填充物体内部的孔洞以及缩小物体的大小。它基于局部区域的最小值,并使区域中的亮度值逐渐减小。

以下是一个使用OpenCV库实现腐蚀操作的简单示例代码:

import cv2import numpy as npdef erode(image, kernel):# 应用腐蚀操作eroded = cv2.erode(image, kernel, iterations=1)return eroded# 读取图像image = cv2.imread('input.jpg', 0)# 定义腐蚀核(结构元素)kernel = np.ones((3, 3), dtype=np.uint8)# 进行腐蚀操作eroded_image = erode(image, kernel)# 显示原始图像和腐蚀后的图像cv2.imshow('Original Image', image)cv2.imshow('Eroded Image', eroded_image)cv2.waitKey(0)cv2.destroyAllWindows()

在上述示例中,我们使用了OpenCV的`erode()`函数来实现腐蚀操作。`erode()`函数接受三个参数,第一个参数是输入图像,第二个参数是腐蚀核(结构元素),第三个参数是迭代次数(默认为1)。最后,通过`imshow()`函数显示原始图像和腐蚀后的图像。

2、膨胀

膨胀(Dilation)是数字图像处理中的一种形态学操作,用于扩展图像中的区域或增加对象的大小。膨胀操作通过卷积输入图像与结构元素(也称为膨胀核)来实现。

膨胀操作可以用于填充物体之间的空隙、连接相邻的对象以及增大物体的大小。它基于局部区域的最大值,并使区域中的亮度值逐渐增大。

以下是一个使用OpenCV库实现膨胀操作的简单示例代码:

import cv2import numpy as npdef dilate(image, kernel):# 应用膨胀操作dilated = cv2.dilate(image, kernel, iterations=1)return dilated# 读取图像image = cv2.imread('input.jpg', 0)# 定义膨胀核(结构元素)kernel = np.ones((3, 3), dtype=np.uint8)# 进行膨胀操作dilated_image = dilate(image, kernel)# 显示原始图像和膨胀后的图像cv2.imshow('Original Image', image)cv2.imshow('Dilated Image', dilated_image)cv2.waitKey(0)cv2.destroyAllWindows()

在上述示例中,我们使用了OpenCV的`dilate()`函数来实现膨胀操作。`dilate()`函数接受三个参数,第一个参数是输入图像,第二个参数是膨胀核(结构元素),第三个参数是迭代次数(默认为1)。最后,通过`imshow()`函数显示原始图像和膨胀后的图像。

3、通用形态学函数

通用形态学函数(General Morphological Function)是一种在形态学图像处理中常用的操作,可以实现腐蚀、膨胀、开运算、闭运算等多种形态学操作。

通用形态学函数结合了腐蚀和膨胀操作,并通过指定结构元素的形状和大小以及操作的类型来完成不同的形态学处理。它可以用于消除噪声、填充孔洞、连接对象、提取特征等应用。

在OpenCV中,可以使用`morphologyEx()`函数来实现通用形态学函数,其函数原型如下:

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


参数说明:
- `src`:输入图像。
- `op`:操作类型,可选值包括`cv2.MORPH_ERODE`(腐蚀)、`cv2.MORPH_DILATE`(膨胀)、`cv2.MORPH_OPEN`(开运算)、`cv2.MORPH_CLOSE`(闭运算)等。
- `kernel`:结构元素(也称为核或腐蚀/膨胀核),用于定义操作的形状和大小。
- `anchor`:锚点位置,默认为`(-1, -1)`表示结构元素的中心。
- `iterations`:操作的迭代次数,默认为1。
- `borderType`:边界扩展类型,默认为`cv2.BORDER_CONSTANT`。
- `borderValue`:边界值,默认为0。以下是一个简单的示例代码,演示了如何使用通用形态学函数进行图像处理操作:

import cv2
import numpy as np# 读取图像
image = cv2.imread('input.jpg', 0)# 定义核(结构元素)
kernel = cv2.getStructuringElement(cv2.MORPH_RECT, (5, 5))# 腐蚀操作
eroded_image = cv2.morphologyEx(image, cv2.MORPH_ERODE, kernel)# 膨胀操作
dilated_image = cv2.morphologyEx(image, cv2.MORPH_DILATE, kernel)# 开运算操作
opened_image = cv2.morphologyEx(image, cv2.MORPH_OPEN, kernel)# 闭运算操作
closed_image = cv2.morphologyEx(image, cv2.MORPH_CLOSE, kernel)# 显示原始图像和处理后的图像
cv2.imshow('Original Image', image)
cv2.imshow('Eroded Image', eroded_image)
cv2.imshow('Dilated Image', dilated_image)
cv2.imshow('Opened Image', opened_image)
cv2.imshow('Closed Image', closed_image)
cv2.waitKey(0)
cv2.destroyAllWindows()


在上述示例中,我们首先定义了一个核(结构元素)`kernel`,然后使用`morphologyEx()`函数分别进行腐蚀、膨胀、开运算和闭运算等操作,并通过`imshow()`函数显示原始图像和处理后的图像。

请注意,通用形态学函数还可以使用更复杂的结构元素(如椭圆形、十字形等)进行形态学操作,并使用适当的参数来控制操作的效果。

4、开运算

开运算(Opening)是形态学图像处理中的一种操作,由腐蚀(Erosion)后接着膨胀(Dilation)两步组成。它可以用于消除图像中小的噪声、平滑边缘、分离相邻物体等。

开运算的操作过程如下:

1. 对输入图像进行腐蚀操作。

2. 对上一步得到的结果进行膨胀操作。

开运算能够将较小的图案或细节从物体边缘剥离出来,同时保持物体整体形状不变。这是因为腐蚀操作会消除较小的细节,而膨胀操作又将物体重新扩展回原来的大小。

以下是一个使用OpenCV库实现开运算的简单示例代码:

import cv2import numpy as npdef opening(image, kernel):# 应用开运算操作opened = cv2.morphologyEx(image, cv2.MORPH_OPEN, kernel)return opened# 读取图像image = cv2.imread('input.jpg', 0)# 定义腐蚀和膨胀核(结构元素)kernel = np.ones((3, 3), dtype=np.uint8)# 进行开运算操作opened_image = opening(image, kernel)# 显示原始图像和开运算后的图像cv2.imshow('Original Image', image)cv2.imshow('Opened Image', opened_image)cv2.waitKey(0)cv2.destroyAllWindows()

在上述示例中,我们首先定义了一个核(结构元素)`kernel`,然后使用`morphologyEx()`函数进行开运算操作,并通过`imshow()`函数显示原始图像和开运算后的图像。

开运算对于去除噪声、平滑边缘以及分离相邻物体等应用非常有效。它可以改善图像质量,减少干扰信息,并提升后续图像处理任务的效果。

5、闭运算

闭运算是数字图像处理中的一种形态学操作,也被称为闭合操作。它由两个基本操作组成:膨胀(dilation)和腐蚀(erosion)。

闭运算首先对图像进行腐蚀操作,然后再对腐蚀结果进行膨胀操作。这两个操作可以通过结构元素(也称为模板或内核)来定义。结构元素是一个小的矩形、圆形或其他形状的矩阵,用于定义腐蚀和膨胀操作的邻域范围。

闭运算的目的是消除图像中的细小空洞并连接相邻的物体。它可以平滑边界并保持物体的整体形状。闭运算通常用于去除噪音、填补断裂或空洞以及改善物体的形状。

在执行闭运算时,先进行腐蚀操作,使图像中的边缘和细小特征变得更小或消失。然后再进行膨胀操作,使原始物体恢复到接近原始大小,并填充空洞。这样就实现了闭运算。

闭运算常用于图像分割、形状分析、目标检测等领域,并且在计算机视觉和图像处理中具有广泛的应用。

闭运算的代码可以使用图像处理库(如OpenCV)来实现。下面是一个使用Python和OpenCV库执行闭运算的示例代码:

import cv2import numpy as np# 读取图像image = cv2.imread('image.jpg', 0) # 以灰度图像方式读取,若为彩色图像则改为cv2.IMREAD_COLOR# 定义结构元素kernel = cv2.getStructuringElement(cv2.MORPH_RECT, (5, 5)) # 5x5的矩形结构元素# 执行闭运算closing = cv2.morphologyEx(image, cv2.MORPH_CLOSE, kernel)# 显示结果cv2.imshow('Original Image', image)cv2.imshow('Closing Result', closing)cv2.waitKey(0)cv2.destroyAllWindows()

在上述代码中,首先通过`cv2.imread()`函数读取输入图像,并将其转换为灰度图像。然后使用`cv2.getStructuringElement()`函数定义了一个5x5的矩形结构元素。接下来,使用`cv2.morphologyEx()`函数执行闭运算,其中第二个参数`cv2.MORPH_CLOSE`表示进行闭运算操作。

最后,使用`cv2.imshow()`函数显示原始图像和闭运算结果,使用`cv2.waitKey()`等待用户按下键盘按键,最后使用`cv2.destroyAllWindows()`关闭窗口。

请注意,以上示例仅为演示闭运算的代码框架,你需要根据你的实际需求进行相应的修改和调整。同时,确保你已经安装了OpenCV库,并将输入图像替换为你自己的图像路径。

相关文章:

OpenCV自学笔记十一:形态学操作(一)

目录 1、腐蚀 2、膨胀 3、通用形态学函数 4、开运算 5、闭运算 1、腐蚀 腐蚀(Erosion)是数字图像处理中的一种形态学操作,用于消除图像中边界附近的细小区域或缩小对象的大小。腐蚀操作通过卷积输入图像与结构元素(也称为腐…...

封装全局异常处理

文章目录 1 定义错误码类2 定义业务异常类3 全局异常处理器4 使用5 前端请求效果总结 1 定义错误码类 ​ 可以定义各种错误码枚举,比如业务,系统相关的报错信息 /*** 错误代码* 错误码** author leovany* date 2023/09/23*/ public enum ErrorCode {SU…...

python的requests响应请求,结果乱码,即使设置了response.encoding也没有用的解决方法

一、问题 如图: 一般出现乱码,我们会有三种解决方式,如下但是图中解决了发现还是不行, response.encodingresponse.apparent_encoding通过看网页源码对response.encodingutf8指定编码格式或者直接通过response.content.decode()来获得源码 出…...

PyCharm 手动下载插件

插件模块一直加载失败,报错信息: Marketplace plugins are not loaded. Check the internet connection and refresh. 尝试了以下方法,均告失败: pip 换源Manage Plugin Repositories...HTTP 代理设置...关闭三个防火墙 最后选…...

Gnomon绑定基础(约束 IK 节点)

点约束 方向约束 父约束 目标约束 修改后 对象方向 IK控制柄 直的骨骼,指定IK怎么弯曲 直的骨骼,指定IK怎么弯曲 样条曲线 数学节点 乘除节点 混合节点 注意...

STL常用遍历,查找,算法

目录 1.遍历算法 1.1for_earch 1.2transform 2.常用查找算法 2.1find,返回值是迭代器 2.1.1查找内置数据类型 2.1.2查找自定义数据类型 2.2fin_if 按条件查找元素 2.2.1查找内置的数据类型 2.2.2查找内置数据类型 2.3查找相邻元素adjeacent_find 2.4查找指…...

BCC源码内容概览(1)

接前一篇文章:BCC源码编译和安装 本文参考官网中的Contents部分的介绍。 BCC源码根目录的文件,其中一些是同时包含C和Python的单个文件,另一些是.c和.py的成对文件,还有一些是目录。 跟踪(Tracing) exam…...

mysql限制用户登录失败次数,限制时间

mysql用户登录限制设置 mysql 需要进行用户登录次数限制,当使用密码登录超过 3 次认证链接失败之后,登录锁住一段时间,禁止登录这里使用的 mysql: 8.1.0 这种方式不用重启数据库. 配置: 首先进入到 mysql 命令行:然后需要安装两个插件: 在 mysql 命令行中执行: mysql> INS…...

从利用Arthas排查线上Fastjson问题到Java动态字节码技术(下)

上一篇从Arthas的源码引出了Java动态字节码技术,那么这一篇就从几种Java字节码技术出发,看看Arthas是如何通过动态字节码技术做到无侵入的源码增强; Java大部分情况下都是解释执行的,也就是解释.class文件,所以如果我们…...

Ubuntu中安装Anaconda 如何将 路径导入为全局变量

第一步:将你的anaconda 路径复制下来,在终端输入对应路径。 echo export PATH"/home/你的用户名/anaconda3/bin:$PATH" >> ~/.bashrc 第二步:在终端输入下面命令或者重启系统。 source ~/.bashrc 在对应的anaconda安装目…...

【QT】Qt的随身笔记(持续更新...)

目录 Qt 获取当前电脑桌面的路径Qt 获取当前程序运行路径Qt 创建新的文本文件txt,并写入内容如何向QPlainTextEdit 写入内容QTimerQMessageBox的使用QLatin1StringQLayoutC在c头文件中写#include类的头文件与直接写class加类名有何区别mutable关键字前向声明 QFontQ…...

【LeetCode-简单题】589. N 叉树的前序遍历

文章目录 题目方法一:单循环栈做法方法二:递归 题目 方法一:单循环栈做法 关键在于子节点的入栈顺序,决定了子节点的出栈顺序, 因为是前序遍历 所以压栈顺序先让右边的入栈 依次往左 这样左边的节点会在栈顶 这样下次…...

Linphone3.5.2 ARM RV1109音视频对讲开发记录

Linphone3.5.2 ARM RV1109音视频对讲开发记录 说明 这是一份事后记录,主要记录的几个核心关键点,有可能很多细节没有记上,主要是方便后面自己再找回来! 版本 3.5.2 一些原因选的是这样一个旧的版本! 新的开发最好选新一些的版…...

Unity用相机实现的镜子效果

首先登场 场景中的元素 mirror是镜子,挂着我们的脚本,Quad是一个面片。Camera是用来生成RenderTexture给面片的。里面的test1是我用来调试位置的球。 镜子size是大小,x是-2,为了反转一下贴图 相机直接可以禁用掉,用…...

计算机网络分类

按照覆盖范围分类 (1)个域网:通常覆盖范围在1~10m。 (2)局域网:通常覆盖范围在10m~1km。 (3)城域网:覆盖范围通常在5~50 km 。 &…...

AI AIgents时代 - (三.) AutoGPT和AgentGPT

前两篇讲解了Agent的原理和组件,这节我将给大家介绍两个agent项目,给出它们的工作原理和区别,并教大家亲手尝试使用 Agents🎉 🟢 AutoGPT🤖️ 我们的老朋友,之前文章也专门写过。AutoGPT 是一…...

Jmeter接口自动化和Python接口自动化,如何选择?

选择Jmeter或Python进行接口自动化测试取决于您的具体需求和环境。以下是一些可以考虑的因素: 1. 语言熟悉度:如果您对Java更熟悉,那么Jmeter可能是更好的选择。而如果您的团队或个人对Python更熟悉,那么Python可能是更好的选择。…...

Sqilte3初步教程

文章目录 安装创建数据库创建和删除表插入行数据 安装 Windows下安装,首先到下载页面,下载Windows安装软件,一般是 sqlite-dll-win32-*.zip sqlite-tools-win32-*.zip下载之后将其内容解压到同一个文件夹下,我把它们都放在了D:\…...

详解Python中的json库

目录 1. json简介2. dumps/loads3. dump/load4. jsonl格式 1. json简介 JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,用于在不同应用程序之间传递数据。它是一种文本格式,易于阅读和编写,同时也易于…...

【Spring Boot】Spring Boot源码解读与原理剖析

这里写目录标题 前言精进Spring Boot首选读物“小册”变“大书”,彻底弄懂Spring Boot全方位配套资源,学不会来找我!技术新赛道,2023领先抢跑 前言 承载着作者的厚望,掘金爆火小册同名读物《Spring Boot源码解读与原理…...

Appium+python自动化(十六)- ADB命令

简介 Android 调试桥(adb)是多种用途的工具,该工具可以帮助你你管理设备或模拟器 的状态。 adb ( Android Debug Bridge)是一个通用命令行工具,其允许您与模拟器实例或连接的 Android 设备进行通信。它可为各种设备操作提供便利,如安装和调试…...

Java求职者面试指南:Spring、Spring Boot、MyBatis框架与计算机基础问题解析

Java求职者面试指南:Spring、Spring Boot、MyBatis框架与计算机基础问题解析 一、第一轮提问(基础概念问题) 1. 请解释Spring框架的核心容器是什么?它在Spring中起到什么作用? Spring框架的核心容器是IoC容器&#…...

JVM 内存结构 详解

内存结构 运行时数据区: Java虚拟机在运行Java程序过程中管理的内存区域。 程序计数器: ​ 线程私有,程序控制流的指示器,分支、循环、跳转、异常处理、线程恢复等基础功能都依赖这个计数器完成。 ​ 每个线程都有一个程序计数…...

Spring Security 认证流程——补充

一、认证流程概述 Spring Security 的认证流程基于 过滤器链(Filter Chain),核心组件包括 UsernamePasswordAuthenticationFilter、AuthenticationManager、UserDetailsService 等。整个流程可分为以下步骤: 用户提交登录请求拦…...

LangChain 中的文档加载器(Loader)与文本切分器(Splitter)详解《二》

🧠 LangChain 中 TextSplitter 的使用详解:从基础到进阶(附代码) 一、前言 在处理大规模文本数据时,特别是在构建知识库或进行大模型训练与推理时,文本切分(Text Splitting) 是一个…...

网页端 js 读取发票里的二维码信息(图片和PDF格式)

起因 为了实现在报销流程中,发票不能重用的限制,发票上传后,希望能读出发票号,并记录发票号已用,下次不再可用于报销。 基于上面的需求,研究了OCR 的方式和读PDF的方式,实际是可行的&#xff…...

【技巧】dify前端源代码修改第一弹-增加tab页

回到目录 【技巧】dify前端源代码修改第一弹-增加tab页 尝试修改dify的前端源代码,在知识库增加一个tab页"HELLO WORLD",完成后的效果如下 [gif01] 1. 前端代码进入调试模式 参考 【部署】win10的wsl环境下启动dify的web前端服务 启动调试…...

可视化预警系统:如何实现生产风险的实时监控?

在生产环境中,风险无处不在,而传统的监控方式往往只能事后补救,难以做到提前预警。但如今,可视化预警系统正在改变这一切!它能够实时收集和分析生产数据,通过直观的图表和警报,让管理者第一时间…...

分布式计算框架学习笔记

一、🌐 为什么需要分布式计算框架? 资源受限:单台机器 CPU/GPU 内存有限。 任务复杂:模型训练、数据处理、仿真并发等任务耗时严重。 并行优化:通过任务拆分和并行执行提升效率。 可扩展部署:适配从本地…...

Flask和Django,你怎么选?

Flask 和 Django 是 Python 两大最流行的 Web 框架,但它们的设计哲学、目标和适用场景有显著区别。以下是详细的对比: 核心区别:哲学与定位 Django: 定位: "全栈式" Web 框架。奉行"开箱即用"的理念。 哲学: "包含…...