第8章:形态学操作

第8章:形态学操作

    • one. 腐蚀操作:
    • two. 膨胀:
    • three. 通用形态学函数:
    • four. 开运算:
    • five. 闭运算:
    • six. 形态学梯度运算:
    • seven. 礼帽运算:
    • eight. 黑帽运算:
    • night. 核函数:

​ 形态学,即数学形态学,是图像处理过程中一个非常重要的研究方向。形态学的目的是提取图像中的分量信息,该分量信息通常对于表达和描绘图像的形状具有重要意义,通常是图像理解时所使用的最本质的形状特征。

​ 例如,我们手写一个阿拉伯数字,在识别时能够通过形态学运算得到其骨架信息,而在具体的图像运算时仅使用其骨架信息即可。

​ 形态学处理广泛应用于视觉检测、文字识别、医学图像识别、图像压缩编码等多个领域。

​ 形态学操作主要包括:腐蚀、膨胀、开运算、闭运算、形态梯度学运算、礼帽运算(顶帽运算)、黑帽运算等操作。腐蚀操作和膨胀操作是形态学运算的基础,将腐蚀和膨胀操作进行结合,就可以实现开运算和闭运算、形态学梯度运算、礼帽运算、黑帽运算、击中击不中等不同形式的运算。

(形态学操作的目的是为了提取图像中总要的分量信息)

one. 腐蚀操作:

​ 腐蚀操作是形态学最基本的操作之一,它能够将图像的边界点消除,使图像沿着边界向内收缩,也可以将小于指定结构体元素的部分去除。(结构体也成为了核)。

​ 腐蚀是用来"收缩"或者"细化二值图像中的前景,借此实现去除噪声、元素分割等功能的。

image-20211029172300548

​ 在腐蚀过程中,通常使用一个结构元来逐个像素的扫描要被腐蚀的图像,并根据结构元和被腐蚀图像的关系来确定腐蚀结果。

image-20211029170840071

​ 例如图中整幅图像的背景色是黑色的,前景对象是一个白色的圆形。图像左上角的深色小方块是遍历图像所使用的结构元。在腐蚀过程中,要将该结构元逐个像素的遍历整个图像,并根据结构元与被腐蚀图像的关系,来确定腐蚀结果图像中对应结构元中心点位置的像素点的像素值。

注意:腐蚀操作等形态学操作都是逐个像素的来决定值的,每次判定的点都是与结构元中心点所对应的点。

下面两幅图像表示结构元与前景色的两种不同关系。根据这两种不同的关系来决定腐蚀结果图像中的结构元中心点所对应位置的像素点的像素值。

  • 如果结构元完全处于前景图像中,就将结构元中心点所对应的腐蚀结果图像中的像素点的像素值处理为前景色(白色,像素点的像素值为1)
  • 如果结构元未完全处于前景图像中(可能部分在,也可能完全不在)就将结构元中心点对应的腐蚀结果图形中的像素点的像素值处理为背景色(黑色,像素点的像素值为0)。

腐蚀的结果就是前景色白色的圆直径变小。结构元也被称为核。

image-20211029171122910

腐蚀函数:

在OpenCV中,使用cv2.erode()函数来实现腐蚀操作,其语法格式为:

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

  • dst:腐蚀后输出的结果图像,该图像和原始图像具有同样的类型和大小。

  • src:原图像,即需要进行腐蚀的原始图像,图像的通道数可以是任意的。但是要求图像的深度必须是CV_8U、CV_16U、CV_16S、CV_32F、CV_64F中的一种。

  • kernel:代表腐蚀操作时所采用的结构类型。它可以自定义生成,也可以通过函数从cv2.getStructutingElement()生成。

  • anchor:代表element结构中锚点的位置。该值默认为(-1, -1),在核中心的位置。

  • iterations:腐蚀操作迭代的次数,该值默认为1,即只进行一次腐蚀操作。

  • borderType:代表边界样式,一般采用其默认值BORDER_CONSTANT。该项的具体值如下所示

    image-20211029171702751

  • borderValue:边界值,一般采用默认值。在C++中提供了函数morphologyDefaultBorderValue()来返回腐蚀和膨胀的"魔力(magic)"边界值,python不支持该函数。

示例1:

import cv2
import numpy as npimg = cv2.imread('../erode.bmp')
kernel = np.ones((5, 5), np.uint8)
rst = cv2.erode(img, kernel)
cv2.imshow('img', img)
cv2.imshow('rst', rst)
cv2.waitKey()
cv2.destroyAllWindows()

image-20211029173453555

示例2:修改腐蚀迭代次数观察

import cv2
import numpy as npimg = cv2.imread('../erode.bmp')
kernel = np.ones((5, 5), np.uint8)
rst = cv2.erode(img, kernel, iterations=5)
cv2.imshow('img', img)
cv2.imshow('rst', rst)
cv2.waitKey()
cv2.destroyAllWindows()

image-20211029175018290

two. 膨胀:

​ 膨胀操作是形态学中另一种基本的操作。**膨胀操作和腐蚀操作的作用是相反的,膨胀操作能够对图像的边界进行扩张。**膨胀操作将背景中与前景对象接触到的像素点合并到前景对象中,从而实现将图像边界点向外扩张。如果图像内两个对象距离较近,那么在膨胀的过程中,两个对象可能会连通在一起。膨胀对填补图像分割后图像内所存在的空白有很大帮助。

image-20211031161519316

同腐蚀的过程一样,在膨胀过程中,也是使用一个结构元(核)来逐个像素扫描被膨胀的图像,并根据结构元和被膨胀图像的关系来确定膨胀结果。

image-20211031161638929

image-20211031162258351

如上图所示:

  • 如果结构元中任意一点处于前景图像中,就将膨胀结果图像中对应像素点处理为前景色。
  • 如果结构元完全处于背景图像外,就将膨胀结果图像中对应像素点处理为背景色。

膨胀操作:

在Opencv中,采用函数cv2.dilate()实现对图像的膨胀操作,其语法结构为:

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

  • dst:膨胀后输出的结果图像,该图像和原始图像具有同样的类型和大小。
  • src:原图像,即需要进行膨胀的原始图像,图像的通道数可以是任意的。但是要求图像的深度必须是CV_8U、CV_16U、CV_16S、CV_32F、CV_64F中的一种。
  • kernel:代表膨胀操作时所采用的结构类型。它可以自定义生成,也可以通过函数从cv2.getStructutingElement()生成。

参数kernel、anchor、iterations、borderType、borderValue与函数cv2.erode()内相应参数的含义一致。

示例1:

import cv2
import numpy as npimg = np.zeros((5, 5), np.uint8)
img[2:3, 1:4] = 1
kernel = np.ones((3, 1), np.uint8)
dilation = cv2.dilate(img, kernel)
print('img=\n', img)
print('kernel=\n', kernel)
print('dilation=\n', dilation)# 输入结果
img=[[0 0 0 0 0][0 0 0 0 0][0 1 1 1 0][0 0 0 0 0][0 0 0 0 0]]
kernel=[[1][1][1]]
dilation=[[0 0 0 0 0][0 1 1 1 0][0 1 1 1 0][0 1 1 1 0][0 0 0 0 0]]

示例2:

import cv2
import numpy as npimg = cv2.imread('../dilate.bmp')
kernel = np.ones((3, 3), np.uint8)
rst = cv2.dilate(img, kernel, iterations=9)
cv2.imshow('img', img)
cv2.imshow('rst', rst)
cv2.waitKey()
cv2.destroyAllWindows()

image-20211031163455048

three. 通用形态学函数:

​ 腐蚀操作和膨胀操作是形态学运算的基础,将腐蚀和膨胀操作进行组合,就可以实现开运算、闭运算(关运算)、形态学梯度(Morphological Gradient)运算、礼帽运算(顶帽运算)、黑帽运算、击中击不中等多种不同形式的运算。

OpenCV提供了函数cv2.morphologyEx()来实现上述形态学运算,其语法结构如下:

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

  • dst:代表经过形态学处理后所输出的目标图像,该图像和原始图像具有同样的类型和大小。

  • src:代表需要进行形态学操作的原始图像。图像的通道数可以是任意的,但是要求图像的深度必须是CV_8U、CV_16U、CV_16S、CV_32F、CV_64F中的一种。

  • op:代表操作类型,如下表所示。各种形态学运算的操作规则,均是将腐蚀膨胀操作进行组合而得到的。

    image-20211031170941335

  • 参数kernel、anchor、iterations、borderType、borderValue与函数cv2.erode()内相应参数的含义一致。

four. 开运算:

开运算进行的操作是先将图像腐蚀,再对腐蚀的结果进行膨胀。开运算可以用于去噪、计数等。

例如,下图中,通过先腐蚀后膨胀的开运算操作实现了去噪,其中:

  • 左图是原始图像。
  • 中间的图是对原始图像进行腐蚀的结果。
  • 右图是对腐蚀后的图像进行膨胀的结果,即对原始图像进行开运算的处理结果。

image-20211031171344812

除此以外,开运算还可以用于计数。例如,在对下图的区域进行计数前,可以利用开运算将连接在一起的不同区域划分开,其中:

  • 左图是原始图像。
  • 中间的图是对原始图像进行腐蚀的结果。
  • 右图是对腐蚀后的图像进行膨胀的结果,即对原始图像进行开运算的处理结果。

image-20211031171530922

通过将函数cv2.morphologyEx()中操作类型参数op设置为“cv2.MORPH_OPEN”,可以实现开运算。其语法结构如下:opening=cv2.morphologyEx(img,cv2.MORPH_OPEN,kernel)

示例:

import cv2
import numpy as npimg1 = cv2.imread('../erode.bmp')
img2 = cv2.imread('../cube.bmp')k = np.ones((20, 20), np.uint8)
rst1 = cv2.morphologyEx(img1, cv2.MORPH_OPEN, k)
rst2 = cv2.morphologyEx(img2, cv2.MORPH_OPEN, k)cv2.imshow('img1', img1)
cv2.imshow('img2', img2)
cv2.imshow('rst1', rst1)
cv2.imshow('rst2', rst2)
cv2.waitKey()
cv2.destroyAllWindows()

image-20211031173543131

five. 闭运算:

​ 闭运算是先膨胀、后腐蚀的运算,它有助于关闭前景物体内部的小孔,或去除物体上的小黑点,还可以将不同的前景图像进行连接。

例如,通过先膨胀后腐蚀的闭运算去除了原始图像内部的小孔(内部闭合的闭运算),其中:

  • 左图是原始图像。

  • 中间的图是对原始图像进行膨胀的结果。

  • 右图是对膨胀后的图像进行腐蚀的结果,即对原始图像进行闭运算的结果。

    image-20211031173857388

除此以外,闭运算还可以实现前景图像的连接。例如,利用闭运算将原本独立的两部分前景图像连接在一起,其中:

  • 左图是原始图像。
  • 中间的图是对原始图像进行膨胀的结果。
  • 右图是对膨胀后的图像进行腐蚀的结果,即对原始图像进行闭运算的结果。

image-20211031174137875

示例:

import cv2
import numpy as npk = np.ones((10, 10), np.uint8)
rst1 = cv2.morphologyEx(img1, cv2.MORPH_CLOSE, k)
cv2.imshow('img1', img1)
cv2.imshow('rst1', rst1)
cv2.waitKey()
cv2.destroyAllWindows()

image-20211031175056956

six. 形态学梯度运算:

​ 形态学梯度运算是用图像的膨胀图像减腐蚀图像的操作,该操作可以获取原始图像中前景图像的边缘。

例如:

image-20211031180412884

示例:

import cv2
import numpy as npimg = cv2.imread('../erode.bmp')k = np.ones((5, 5), np.uint8)
rst = cv2.morphologyEx(img, cv2.MORPH_GRADIENT, k)
cv2.imshow('img', img)
cv2.imshow('rst', rst)
cv2.waitKey()
cv2.destroyAllWindows()

image-20211031180804983

seven. 礼帽运算:

礼帽运算是用原始图像减去其开运算图像的操作。礼帽运算能够获取图像的噪声信息,或者得到比原始图像的边缘更亮的边缘信息。

例如

  • 左图是原始图像。
  • 中间的图是开运算图像。
  • 右图是原始图像减开运算图像所得到的礼帽图像。

image-20211031181039316

示例:

import cv2
import numpy as npimg1 = cv2.imread('../erode.bmp')
img2 = cv2.imread('../lena.bmp')k = np.ones((5, 5), np.uint8)
rst1 = cv2.morphologyEx(img1, cv2.MORPH_TOPHAT, k)
rst2 = cv2.morphologyEx(img2, cv2.MORPH_TOPHAT, k)
cv2.imshow('img1', img1)
cv2.imshow('img2', img2)
cv2.imshow('rst1', rst1)
cv2.imshow('rst2', rst2)
cv2.waitKey()
cv2.destroyAllWindows()

image-20211031181601260

eight. 黑帽运算:

​ 黑帽运算是用闭运算图像减去原始图像的操作。黑帽运算能够获取图像内部的小孔,或前景色中的小黑点,或者得到比原始图像的边缘更暗的边缘部分。

例如:

  • 左图是原始图像。
  • 中间的图是闭运算图像。
  • 右图是使用闭运算图像减原始图像所得到的黑帽图像。

image-20211031183651982

示例:

import cv2
import numpy as npimg1 = cv2.imread('../noise2.bmp')
img2 = cv2.imread('../lena.bmp')k = np.ones((10, 10), np.uint8)
rst1 = cv2.morphologyEx(img1, cv2.MORPH_BLACKHAT, k)
rst2 = cv2.morphologyEx(img2, cv2.MORPH_BLACKHAT, k)
cv2.imshow('img1', img1)
cv2.imshow('img2', img2)
cv2.imshow('rst1', rst1)
cv2.imshow('rst2', rst2)
cv2.waitKey()
cv2.destroyAllWindows()

image-20211031184029274

night. 核函数:

​ 在进行形态学操作时,必须使用一个特定的核(结构元)。该核可以自定义生成,也可以通过函数 cv2.getStructuringElement()构造。函数 cv2.getStructuringElement()能够构造并返回一个用于形态学处理所使用的结构元素。该函数的语法格式为:

  • retval=cv2.getStructuringElement(shape,ksize[,anchor])

该函数用来返回一个用于形态学操作的指定大小和形状的结构元素。函数中的参数含义如下。

  • shape代表形状类型,其可能的取值如表所示。

image-20211031184449741

  • ksize 代表结构元素的大小。
  • anchor 代表结构元素中的锚点位置。默认的值是(-1,-1),是形状的中心。只有十字星型的形状与锚点位置紧密相关。在其他情况下,锚点位置仅用于形态学运算结果的调整。

当然,除了使用该函数,用户也可以自己构建任意二进制掩码作为形态学操作中所使用的结构元素。

示例1:使用函数cv2.getStructuringElement()生成不同结构的核。

import cv2k1 = cv2.getStructuringElement(cv2.MORPH_RECT, (5, 5))
k2 = cv2.getStructuringElement(cv2.MORPH_CROSS, (5, 5))
k3 = cv2.getStructuringElement(cv2.MORPH_ELLIPSE, (5, 5))print('k1=\n', k1)
print('k2=\n', k2)
print('k3=\n', k3)# 输出结果
k1=[[1 1 1 1 1][1 1 1 1 1][1 1 1 1 1][1 1 1 1 1][1 1 1 1 1]]
k2=[[0 0 1 0 0][0 0 1 0 0][1 1 1 1 1][0 0 1 0 0][0 0 1 0 0]]
k3=[[0 0 1 0 0][1 1 1 1 1][1 1 1 1 1][1 1 1 1 1][0 0 1 0 0]]

示例2:使用不同的核进行形态学操作

import cv2img = cv2.imread('../round.bmp')k1 = cv2.getStructuringElement(cv2.MORPH_RECT, (25, 25))
k2 = cv2.getStructuringElement(cv2.MORPH_CROSS, (25, 25))
k3 = cv2.getStructuringElement(cv2.MORPH_ELLIPSE, (25, 25))rst1 = cv2.erode(img, k1, iterations=3)
rst2 = cv2.erode(img, k2, iterations=3)
rst3 = cv2.erode(img, k3, iterations=3)
cv2.imshow('img', img)
cv2.imshow('rst1', rst1)
cv2.imshow('rst2', rst2)
cv2.imshow('rst3', rst3)
cv2.waitKey()
cv2.destroyAllWindows()

image-20211031190033032

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

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

相关文章

【树莓派学习笔记】四、OpenCV的安装与卸载

目录安装修改host以连接上Github测试IP修改树莓派的hosts安装各种依赖包安装OpenCV只安装核心模块安装核心模块和opencv_contribC Opencv 测试编写测试源码编译测试卸载平台:树莓派3B 版本: 2021-05-07-raspios-buster-armhf 安装 修改host以连接上Git…

MySQL ERROR 1071 (42000): Specified key was too long; max key length is 767 bytes

今天在使用mysql时,又遇到了如博文标题所示的问题,以前针对该问题未进行记录,今天特意进行说明存档。 该问题是由键值字段长度过长导致。mysql支持数据库表单一键值的最大长度不能超过767字节,超出这个长度即报错&#xf…

转载:用大白话聊聊分布式系统

转载:http://blog.csdn.net/zhousenshan/article/details/71304922?locationNum10&fps1转载于:https://www.cnblogs.com/wdh1995/p/7067985.html

IE 弹出框处理经验

//各屏幕弹出窗样式 // 1366*768var style_1366x768 "dialogWidth:950px;dialogHeight:650px;help:no;center:yes;status:no;resizable:no;location:yes;"; //弹出窗口示例代码function showDialog(url,title,style) { window.showModalDialog(url, title, style…

第9章:图像梯度

第9章:图像梯度one. Sobel理论基础1. 计算水平方向偏导数的近似值2. 计算垂直方向偏导数的近似值two. Sobel算子及函数的使用:1. 函数语法:2. 对像素取绝对值:3. 方向:three. Scharr 算子及函数使用:1. 函数语法:2. 实…

FreeBSD9.1安装Gnome2桌面

1. #pkg_add -r xorg gnome2 gdm2. #ee /etc/rc.conf  加入hald_enable"YES" dbus_enable"YES gdm_enable"YES" gnome_enable"YES" 3. # /usr/local/etc/rc.d/dbus start # /usr/local/etc/rc.d/hald start4. # ee /etc/fstab 加入pro…

【树莓派学习笔记】五、处理、自动重命名并另存为图片

目录编写源码编译测试平台&#xff1a;树莓派3B 版本&#xff1a; 2021-05-07-raspios-buster-armhf 编写源码 所用源码修改自【机器视觉学习笔记】最近邻插值实现图片任意角度旋转&#xff08;C&#xff09; 在合适的地方编写源码 nano main.cpp#include <opencv2/openc…

【bzoj3744】Gty的妹子序列 分块+树状数组+主席树

题目描述 我早已习惯你不在身边&#xff0c;人间四月天 寂寞断了弦。回望身后蓝天&#xff0c;跟再见说再见……某天,蒟蒻Autumn发现了从 Gty的妹子树(bzoj3720) 上掉落下来了许多妹子,他发现她们排成了一个序列,每个妹子有一个美丽度。Bakser神犇与他打算研究一下这个妹子序列…

Linux系统软件包的管理   3月30日课程

Linux系统软件包的管理一、 rpm工具rpm Redhat Package Manager&#xff0c; 设计理念是开放的&#xff0c;不仅仅是在RedHat平台上&#xff0c;在SUSE上也是可以使用的。rpm包名字构成由-和.分成了若干部分&#xff0c;如abrt-cli-2.0.8-15.el6.centos.i686.rpm&#xff0c;ab…

第10章:Canny图像边缘检测

第10章&#xff1a;Canny图像边缘检测一、Canny边缘检测的基础&#xff1a;1. 应用高斯滤波去除图像噪声&#xff1a;2. 计算梯度3.非极大值抑制4. 应用双阈值确定边缘&#xff1a;二、Canny函数使用&#xff1a;​ Canny边缘检测是一种使用多级边缘检测算法检测边缘的方法。19…

【树莓派学习笔记】六、启用摄像头、实时视频、录像和截图

目录安装摄像头配置使用luvcview平台&#xff1a;树莓派3B 版本&#xff1a; 2021-05-07-raspios-buster-armhf 安装摄像头 配置 sudo raspi-config重启后 cd /dev ls可看到新增了video0设备 使用luvcview 安装 sudo apt-get install luvcview查看摄像设备详细信息 luv…

https 与 http

HTTPS,HTTP over SSL,SSL是解决传输层安全问题的网络协议&#xff0c;其核心是基于公钥密码学理论实现了对服务器身份认证&#xff0c;数据的私密性保护以及对数据完整性的校验等功能。 SSL协议在HTTP请求开始之前增加了握手阶段&#xff0c;SSL/TLS握手———加密的HTTP请求—…

Android各种屏幕分辨率(VGA、HVGA、QVGA、WQVGA、WVGA、FWVGA) 详解

2019独角兽企业重金招聘Python工程师标准>>> VGA&#xff1a;Video Graphics Array&#xff0c;即&#xff1a;显示绘图矩阵&#xff0c;相当于640480 像素&#xff1b;HVGA&#xff1a;Half-size VGA&#xff0c;即&#xff1a;VGA的一半&#xff0c;分辨率为48032…

敏捷合同-摘自网络

敏捷软件开发实践的文化中存在着一个断层&#xff0c;该断层同样体现在许多敏捷团队中。这个断层就是业务分析人员在敏捷项目中的角色——谁来担任这个角色&#xff1f;它的作用 和价值是什么&#xff1f;它又是如何发生改变的&#xff1f;这种情况的潜台词&#xff08;其实我曾…

第11章:图像金字塔

第11章&#xff1a;图像金字塔一、理论基础&#xff1a;1. 向下采样&#xff1a;2. 向上采样&#xff1a;二、pyrDown函数使用&#xff1a;三、pyrUp函数及使用&#xff1a;四、采样可逆性研究五、拉普拉斯金字塔1. 定义&#xff1a;2. 应用&#xff1a;什么是图像金子塔&#…

【树莓派学习笔记】七、(免费)内网穿透将树莓派作为服务器管理网站

目录nginx安装开机自启动测试查看nginx安装路径查看配置文件路径(测试用)修改index.nginx-debian.html内网穿透免费方案ngrok原版方案下载ngrok连接账户开启内网穿透httpSSH网云穿方案开通隧道下载开启内网穿透开机自启动花生壳方案下载和安装添加内网穿透映射测试平台&#xf…

webapi put 404

windows server 2016 IIS webapi 404 error In IIS select your website and double-click Handler Mappings &#xff08;处理程序映射&#xff09;Find ExtensionlessUrlHandler-ISAPI-4.0_32bit and double-clickIn the dialog that appears, click Request Restrictio…

linux批量远程多服务器FTP并下载文件的脚本

#!/bin/bashtimedate %Y%mdaydate -d -1 days %Y%m%dlocalDir"/DBBackup/GameDB"cd $localDir#ip_game.ini配置ftp服务器的ip,账号&#xff0c;密码等&#xff0c;格式自己定义 #比如&#xff1a;Server1 username userpasswd 1.1.1.1 Dbbackup servername(cat /D…

第12章:图像轮廓

第12章&#xff1a;图像轮廓一、查找并绘制轮廓&#xff1a;1. 查找图像轮廓&#xff1a;2. 绘制图像轮廓&#xff1a;3. 绘制轮廓实例&#xff1a;二、矩特征1. 矩的计算&#xff1a;moments函数2. 计算轮廓面积&#xff1a;contourArea函数3. 计算轮廓长度&#xff1a;arcLen…

【语言处理与Python】2.5WordNet

WordNet是面向语义的英语词典&#xff0c;类似于传统词典&#xff0c;但具有更丰富的结构。NLTK中包括英语WordNet,有很多词和同义词的集合。 意义与同义词 具有相同含义的词是同义词。 #在wordnet中怎样探索这些同义词from nltk.corpus import wordnet as wnWn.synsets(‘moto…