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源码解读与原理…...
Java 8 Stream API 入门到实践详解
一、告别 for 循环! 传统痛点: Java 8 之前,集合操作离不开冗长的 for 循环和匿名类。例如,过滤列表中的偶数: List<Integer> list Arrays.asList(1, 2, 3, 4, 5); List<Integer> evens new ArrayList…...
从深圳崛起的“机器之眼”:赴港乐动机器人的万亿赛道赶考路
进入2025年以来,尽管围绕人形机器人、具身智能等机器人赛道的质疑声不断,但全球市场热度依然高涨,入局者持续增加。 以国内市场为例,天眼查专业版数据显示,截至5月底,我国现存在业、存续状态的机器人相关企…...
c++ 面试题(1)-----深度优先搜索(DFS)实现
操作系统:ubuntu22.04 IDE:Visual Studio Code 编程语言:C11 题目描述 地上有一个 m 行 n 列的方格,从坐标 [0,0] 起始。一个机器人可以从某一格移动到上下左右四个格子,但不能进入行坐标和列坐标的数位之和大于 k 的格子。 例…...
tree 树组件大数据卡顿问题优化
问题背景 项目中有用到树组件用来做文件目录,但是由于这个树组件的节点越来越多,导致页面在滚动这个树组件的时候浏览器就很容易卡死。这种问题基本上都是因为dom节点太多,导致的浏览器卡顿,这里很明显就需要用到虚拟列表的技术&…...
分布式增量爬虫实现方案
之前我们在讨论的是分布式爬虫如何实现增量爬取。增量爬虫的目标是只爬取新产生或发生变化的页面,避免重复抓取,以节省资源和时间。 在分布式环境下,增量爬虫的实现需要考虑多个爬虫节点之间的协调和去重。 另一种思路:将增量判…...
有限自动机到正规文法转换器v1.0
1 项目简介 这是一个功能强大的有限自动机(Finite Automaton, FA)到正规文法(Regular Grammar)转换器,它配备了一个直观且完整的图形用户界面,使用户能够轻松地进行操作和观察。该程序基于编译原理中的经典…...
JVM 内存结构 详解
内存结构 运行时数据区: Java虚拟机在运行Java程序过程中管理的内存区域。 程序计数器: 线程私有,程序控制流的指示器,分支、循环、跳转、异常处理、线程恢复等基础功能都依赖这个计数器完成。 每个线程都有一个程序计数…...
Bean 作用域有哪些?如何答出技术深度?
导语: Spring 面试绕不开 Bean 的作用域问题,这是面试官考察候选人对 Spring 框架理解深度的常见方式。本文将围绕“Spring 中的 Bean 作用域”展开,结合典型面试题及实战场景,帮你厘清重点,打破模板式回答,…...
苹果AI眼镜:从“工具”到“社交姿态”的范式革命——重新定义AI交互入口的未来机会
在2025年的AI硬件浪潮中,苹果AI眼镜(Apple Glasses)正在引发一场关于“人机交互形态”的深度思考。它并非简单地替代AirPods或Apple Watch,而是开辟了一个全新的、日常可接受的AI入口。其核心价值不在于功能的堆叠,而在于如何通过形态设计打破社交壁垒,成为用户“全天佩戴…...
Qt 事件处理中 return 的深入解析
Qt 事件处理中 return 的深入解析 在 Qt 事件处理中,return 语句的使用是另一个关键概念,它与 event->accept()/event->ignore() 密切相关但作用不同。让我们详细分析一下它们之间的关系和工作原理。 核心区别:不同层级的事件处理 方…...
