【OpenCV C++20 学习笔记】腐蚀和膨胀

腐蚀和膨胀

  • 形态学原理
    • 膨胀
    • 腐蚀
  • 代码实现
    • 膨胀函数
    • 腐蚀函数
    • 运行结果

形态学原理

腐蚀和膨胀通常有以下用途:

  • 去除噪音
  • 分离或合并图像中的元素
  • 找出图片上的强度的极大值区域和极小值区域
    以下图作为原始图片:

原始图片

膨胀

用核 B B B来扫描图像 A A A,核 B B B中有个锚点,通常是核的中心。在扫描图像的时候,被 B B B覆盖的 A A A的区域上的最大值将会被赋予核 B B B的锚点。这样图片中像素值高的区域(亮的区域)将会扩大,这就是“膨胀”。如下图所示:
膨胀变换示意图

用数学公式来表达就是:
d s t ( x , y ) = m a x ( x ′ , y ′ ) : e l e m e n t ( x ′ , y ′ ) ≠ 0 s r c ( x + x ′ , y + y ′ ) dst(x,y)=max_{(x', y'):element(x',y')\neq0}src(x+x',y+y') dst(x,y)=max(x,y):element(x,y)=0src(x+x,y+y)

  • d s t ( x , y ) dst(x,y) dst(x,y) x x x y y y列的像素值的膨胀结果
  • s r c ( x , y ) src(x,y) src(x,y) x x x y y y列的原始像素值
  • x ′ x' x y ′ y' y分别为最大值在核中的坐标

膨胀后的效果:
膨胀后的效果

腐蚀

腐蚀的操作与膨胀正好相反,它将核 B B B中的最小值赋予核的锚点。这样像素值小的区域(暗的区域)就会变多。如下图所示:
腐蚀变换示意图

用数学公式表达如下:
d s t ( x , y ) = m i n ( x ′ , y ′ ) : e l e m e n t ( x ′ , y ′ ) ≠ 0 s r c ( x + x ′ , y + y ′ ) dst(x,y)=min_{(x', y'):element(x',y')\neq0}src(x+x',y+y') dst(x,y)=min(x,y):element(x,y)=0src(x+x,y+y)

  • d s t ( x , y ) dst(x,y) dst(x,y) x x x y y y列的像素值的膨胀结果
  • s r c ( x , y ) src(x,y) src(x,y) x x x y y y列的原始像素值
  • x ′ x' x y ′ y' y分别为最大值在核中的坐标

腐蚀效果如下:
腐蚀后的效果

代码实现

在OpenCV中,在进行膨胀和腐蚀操作前都必须先创建用来扫描原始图片的“核”,这就要用到getStructuringElement()函数:

Mat element = getStructuringElement(MORPH_RECT,		//核的形态Size(3, 3),		//核的尺寸,默认3*3Point(-1, -1));	//核的锚点,(-1,-1)表示核的中心

其中第1个参数,有以下枚举类型:

  • MORPH_RECT:矩形
  • MORPH_CROSS:十字形
  • MORPH_ELLIPSE:椭圆形

这样就会自动创建全是1的一个卷积核矩阵,如下图:
卷积核矩阵

接下来就可以进行膨胀和腐蚀操作了:

膨胀函数

膨胀函数非常简单:

dilate(image,	//原图DImage,		//目标图element);	//核

腐蚀函数

腐蚀函数也非常简单:

erode(image,	//原图EImage,		//目标图element);	//核

运行结果

中间是原图,左边是膨胀,右边是腐蚀:
膨胀和腐蚀对比原图

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

VBA学习(22):动态显示日历

这是在ozgrid.com论坛上看到的一个贴子,很有意思,本来使用公式是可以很方便在工作表中实现日历显示的,但提问者因其需要,想使用VBA实现动态显示日历,即根据输入的年份和月份在工作表中显示日历。 下面是实现该效果的VB…

喜报!DAP-seq文章6连发,总IF 95.2

2024年4月29日,河北农业大学林学院李保国山区产业开发与林果产业创新团队与园艺学院田义教授团队联合西北农林科技大学马锋旺教授团队及沈阳农业大学马跃教授团队在Plant Biotechnology Journal(影响因子10.1)上发表了题为“The MdVQ37-MdWRK…

2024最新版Python基础入门学习路线

Python基础入门学习路线可以概括为以下几个阶段,每个阶段都包含了关键的学习内容和目标: 一、Python语言基础 1. 初识Python语言 Python语言概述:了解Python的起源、特点、应用领域以及发展趋势。环境安装:学习如何在不同的操作系…

18987 随机数(测验)

这个问题可以通过使用集合(set)和排序来解决。集合是一种数据结构,它可以自动去除重复的元素。然后我们可以将集合中的元素转移到一个数组中,并对��组进行排序。 以下是使用C的代码实现: #i…

浅谈哈希与哈希表(c++)

目录 一、哈希的基本概念(一)哈希函数的特性(二)哈希冲突 二、C 中的哈希表实现三、哈希表的性能分析四、哈希表的应用场景五、优化哈希表的策略六、例题讲解【模板】字符串哈希题目描述输入格式输出格式样例 #1样例输入 #1样例输…

工业5G路由器赋能户外组网远程监控及预警

随着物联网、大数据、云计算等技术的快速发展,工业领域对于远程监控、实时预警和数据传输的需求日益增长。特别是在户外复杂环境下,传统的有线网络组网方式面临着布线难度大、成本高、维护困难等问题。 工业5G路由器在户外组网远程监控预警应用基于高速…

Android开发之事件分发

#来自ウルトラマンゼロ(哉阿斯) 1 Activity 构成 平常布局展示在ContentView中。 2 事件分发 事件分发的本质其实就是把事件(Touch)封装成 MotionEvent 类,然后传递给 View 的层级处理。 MotionEvent 事件类型主要有…

RAG与Fine Tuning:如何选择正确的方法

今日份知识你摄入了么? 生成式人工智能有潜力改变你的业务和数据工程团队,但前提是要正确实施。那么,你的数据团队如何才能真正利用大型语言模型或生成式人工智能_(GenAI)_计划来驱动价值呢? 领先的组织通…

我在高职教STM32——I2C通信入门(1)

大家好,我是老耿,高职青椒一枚,一直从事单片机、嵌入式、物联网等课程的教学。对于高职的学生层次,同行应该都懂的,老师在课堂上教学几乎是没什么成就感的。正是如此,才有了借助CSDN平台寻求认同感和成就感的想法。在这里,我准备陆续把自己花了很多心思设计的教学课件分…

Sentinel-1 Level 1数据处理的详细算法定义(五)

《Sentinel-1 Level 1数据处理的详细算法定义》文档定义和描述了Sentinel-1实现的Level 1处理算法和方程,以便生成Level 1产品。这些算法适用于Sentinel-1的Stripmap、Interferometric Wide-swath (IW)、Extra-wide-swath (EW)和Wave模式。 今天介绍的内容如下: Sentinel-1 L…

Python爬虫新手指南及简单实战

网络爬虫是自动化获取网络信息的高效工具,Python因其强大的库支持和简洁的语法成为编写网络爬虫的首选语言。本教程将通过一个具体的案例(基于Microsoft Edge浏览器的简单爬取),指导你使用Python实现一个完整的网络爬虫&#xff0…

NIO专题学习(一)

一、BIO/NIO/AIO介绍 1. 背景说明 在Java的软件设计开发中,通信架构是不可避免的。我们在进行不同系统或者不同进程之间的数据交互,或者在高并发的通信场景下都需要用到网络通信相关的技术。 对于一些经验丰富的程序员来说,Java早期的网络…

PXE 服务器搭建——启动界面设计实验

环境准备: 前期准备: 解决 kickstart 实验出现的 DHCP 的问题-CSDN博客 http://t.csdnimg.cn/5vZP0 当前准备: 两台虚拟机:RHEL7 OpenEuler(作为测试机器使用) ip:172.25.254.100 yum install syslinux.x…

【Web开发手礼】探索Web开发的秘密(十五)-Vue2(2)AJAX、前后端分离、前端工程化

主要介绍了AJAX、前后端分离所需的YApi、前端工程化所需要的环境安装!!! 目录 前言 AJAX ​原生Ajax Axios Axios入门 案例 前后端分离开发 YApi ​前端工程化 环境准备 总结 前言 主要介绍了AJAX、前后端分离所需的YApi、前端工…

2024华数杯c题题解(一)

目录 原题背景 背景分析 问题一 思路 代码 问题二 思路 代码 原题背景 最近,“city 不 city”这一网络流行语在外国网红的推动下备受关注。随着我国过境免签政策的落实,越来越多外国游客来到中国,通过网络平台展示他们在华旅行的见闻…

出现 No mapping for DELETE/GET等

出现 No mapping for DELETE/GET等 错误一:请求url不对 修改前 如下图可知后端请求url为http://localhost:8080/user/addressBook 运行后控制台出现 发现后端请求url比前端请求url少了/ 改正: 在DeleteMapping后面加上 / DeleteMapping("/&quo…

mysql操作(进阶)

1.数据库约束 数据库自动对数据的合法性进行校验检查的一系列机制,目的是为了保证数据库中能够避免被插入或者修改一些非法数据。 (1)mysql中提供了以下的约束: a.NOT NULL:指定某列不能为null b.UNIQUE&#xff1…

搭建pxe网络安装环境实现服务器自动部署

目录 配置 kickstart自动安装脚本 搭建dhcp服务 搭建pxe网络安装环境实现服务器自动部署 测试 配置 kickstart自动安装脚本 yum install system-config-kickstart #在rhel7做,rhel9要收费 system-config-kickstart #启动图形制作工具 vim …

工具收集 - tinytask(相当于迷你的按键精灵)

工具收集 - tinytask(相当于迷你的按键精灵) 简介首页 简介 TinyTask 是一款极简主义的 PC 自动化应用程序,您可以用它来记录和重复操作。顾名思义,它小得令人难以置信(仅 36KB!),极…

C++第三十一弹---C++继承机制深度剖析(下)

✨个人主页: 熬夜学编程的小林 💗系列专栏: 【C语言详解】 【数据结构详解】【C详解】 1.菱形继承及菱形虚拟继承 1.1 单继承 单继承:一个子类只有一个直接父类时称这个继承关系为单继承。 Student的直接父类是Person&#xff…