IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> opencv 形态学操作(python) -> 正文阅读

[人工智能]opencv 形态学操作(python)

形态学操作

形态学,即数学形态学(Mathematical Morphology),是图像处理过程中一个非常重要的研究方向。

形态学主要从图像内提取分量信息,该分量信息通常对于表达和描绘图像的形状具有重要意义,通常是图像理解时所使用的最本质的形状特征。

形态学操作主要包含:腐蚀、膨胀、开运算、闭运算、形态学梯度(Morphological Gradient)运算、顶帽运算(礼帽运算)、黑帽运算等操作。

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

腐蚀

它能够将图像的边界点消除,使图像沿着边界向内收缩,也可以将小于指定结构体元素的部分去除。

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

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

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

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

在kernel完全位于前景图象中时,将其中心点所对应的rst中像素点的值置为1;当kernel不完全位于前景图像中时,将其中心点对应的rst中像素点的值置为0。

使用函数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.getStructuringElement()生成。

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

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

  • borderType代表边界样式,一般采用其默认值BORDER_CONSTANT。

    image-20220506184737557

  • borderValue是边界值,一般采用默认值。

    在C++中提供了函数morphologyDefaultBorderValue()来返回腐蚀和膨胀的“魔力(magic)”边界值,Python不支持该函数。

使用数组演示腐蚀的基本原理

import cv2 
import numpy as np 
img=np.zeros((5,5), np.uint8) 
img[1:4,1:4]=1 
kernel = np.ones((3,1), np.uint8) 
erosion = cv2.erode(img, kernel) 
print("img=\n", img) 
print("kernel=\n", kernel) 
print("erosion=\n", erosion) 

使用函数cv2.erode()完成图像腐蚀

import cv2 
import numpy as np 
o=cv2.imread("erode.bmp", cv2.IMREAD_UNCHANGED) 
kernel = np.ones((5,5), np.uint8) 
erosion = cv2.erode(o, kernel) 
cv2.imshow("orriginal", o) 
cv2.imshow("erosion", erosion) 
cv2.waitKey() 
cv2.destroyAllWindows()

处理图像是: 二值图像

膨胀

膨胀操作和腐蚀操作的作用是相反的,膨胀操作能对图像的边界进行扩张。膨胀操作将与当前对象(前景)接触到的背景点合并到当前对象内,从而实现将图像的边界点向外扩张。

如果图像内两个对象的距离较近,那么在膨胀的过程中,两个对象可能会连通在一起。膨胀操作对填补图像分割后图像内所存在的空白相当有帮助。

在膨胀过程中,也是使用一个结构元来逐个像素地扫描要被膨胀的图像,并根据结构元和待膨胀图像的关系来确定膨胀结果。

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

采用函数cv2.dilate()实现对图像的膨胀操作:

dst = cv2.dilate( src, kernel[, anchor[, iterations[, borderType[, borderValue]]]]) 
  • dst代表膨胀后所输出的目标图像,该图像和原始图像具有同样的类型和大小。

  • src代表需要进行膨胀操作的原始图像。图像的通道数可以是任意的,但是要求图像的类型必须是CV_8U、CV_16U、CV_16S、CV_32F、CV_64F中的一种。

  • element代表膨胀操作所采用的结构类型。它可以自定义生成,也可以通过函数cv2.getStructuringElement()生成。

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

使用数组演示膨胀的基本原理

import cv2 
import numpy as np 
img=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) 

使用函数cv2.dilate()完成图像膨胀操作

import cv2 
import numpy as np 
o=cv2.imread("dilation.bmp", cv2.IMREAD_UNCHANGED) 
kernel = np.ones((9,9), np.uint8) 
dilation = cv2.dilate(o, kernel) 
# dilation = cv2.dilate(o, kernel, iterations = 9) # iterations = 9对迭代次数进行控制,让膨胀重复9次
cv2.imshow("original", o) 
cv2.imshow("dilation", dilation) 
cv2.waitKey() 
cv2.destroyAllWindows() 
通用形态学函数

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

函数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-20220506185826344

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

开运算

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

通过将函数cv2.morphologyEx()中操作类型参数op设置为“cv2.MORPH_OPEN”,可以实现开运算。

opening = cv2.morphologyEx(img, cv2.MORPH_OPEN, kernel)
import cv2 
import numpy as np 
img1=cv2.imread("opening.bmp") 
img2=cv2.imread("opening2.bmp") 
k=np.ones((10,10), np.uint8) 
r1=cv2.morphologyEx(img1, cv2.MORPH_OPEN, k) 
r2=cv2.morphologyEx(img2, cv2.MORPH_OPEN, k) 
cv2.imshow("img1", img1) 
cv2.imshow("result1", r1) 
cv2.imshow("img2", img2) 
cv2.imshow("result2", r2) 
cv2.waitKey() 
cv2.destroyAllWindows() 
闭运算

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

内部闭合的闭运算

原始图像在经过膨胀、腐蚀后,实现了闭合内部小孔的目的

闭运算还可以实现前景图像的连接。

通过将函数cv2.morphologyEx()中操作类型参数op设置为“cv2.MORPH_CLOSE”,可以实现闭运算。

closing = cv2.morphologyEx(img, cv2.MORPH_CLOSE, kernel)
import cv2 
import numpy as np 
img1=cv2.imread("closing.bmp") 
img2=cv2.imread("closing2.bmp") 
k=np.ones((10,10), np.uint8) 
r1=cv2.morphologyEx(img1, cv2.MORPH_CLOSE, k, iterations=3) 
r2=cv2.morphologyEx(img2, cv2.MORPH_CLOSE, k, iterations=3) 
cv2.imshow("img1", img1) 
cv2.imshow("result1", r1) 
cv2.imshow("img2", img2) 
cv2.imshow("result2", r2) 
cv2.waitKey() 
cv2.destroyAllWindows()
形态学梯度运算

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

通过将函数cv2.morphologyEx()的操作类型参数op设置为“cv2.MORPH_GRADIENT”,可以实现形态学梯度运算。

result = cv2.morphologyEx(img, cv2.MORPH_GRADIENT, kernel)
import cv2 
import numpy as np 
o=cv2.imread("gradient.bmp", cv2.IMREAD_UNCHANGED) 
k=np.ones((5,5), np.uint8) 
r=cv2.morphologyEx(o, cv2.MORPH_GRADIENT, k) 
cv2.imshow("original", o) 
cv2.imshow("result", r) 
cv2.waitKey() 
cv2.destroyAllWindows() 
礼帽运算

礼帽运算是用原始图像减去其开运算图像的操作。

礼帽运算能够获取图像的噪声信息,或者得到比原始图像的边缘更亮的边缘信息。

通过将函数cv2.morphologyEx()中操作类型参数op设置为“cv2.MORPH_TOPHAT”,可以实现礼帽运算。

result = cv2.morphologyEx(img, cv2.MORPH_TOPHAT, kernel) 
import cv2 
import numpy as np 
o1=cv2.imread("tophat.bmp", cv2.IMREAD_UNCHANGED) 
o2=cv2.imread("lena.bmp", cv2.IMREAD_UNCHANGED) 
k=np.ones((5,5), np.uint8) 
r1=cv2.morphologyEx(o1, cv2.MORPH_TOPHAT, k) 
r2=cv2.morphologyEx(o2, cv2.MORPH_TOPHAT, k) 
cv2.imshow("original1", o1) 
cv2.imshow("original2", o2) 
cv2.imshow("result1", r1) 
cv2.imshow("result2", r2) 
cv2.waitKey() 
cv2.destroyAllWindows() 
黑帽运算

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

通过将函数cv2.morphologyEx()中操作类型参数op设置为“cv2.MORPH_BLACKHAT”,可以实现黑帽运算。

result = cv2.morphologyEx(img, cv2.MORPH_BLACKHAT, kernel) 
import cv2 
import numpy as np 
o1=cv2.imread("blackhat.bmp", cv2.IMREAD_UNCHANGED) 
o2=cv2.imread("lena.bmp", cv2.IMREAD_UNCHANGED) 
k=np.ones((5,5), np.uint8) 
r1=cv2.morphologyEx(o1, cv2.MORPH_BLACKHAT, k) 
r2=cv2.morphologyEx(o2, cv2.MORPH_BLACKHAT, k) 
cv2.imshow("original1", o1) 
cv2.imshow("original2", o2) 
cv2.imshow("result1", r1) 
cv2.imshow("result2", r2) 
cv2.waitKey() 
cv2.destroyAllWindows() 
核函数

在进行形态学操作时,必须使用一个特定的核(结构元)。

该核可以自定义生成,也可以通过函数cv2.getStructuringElement()构造。

函数cv2.getStructuringElement()能够构造并返回一个用于形态学处理所使用的结构元素。

该函数的语法格式为:

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

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

  • shape代表形状类型

    image-20220506190946161

  • ksize代表结构元素的大小

  • anchor代表结构元素中的锚点位置。默认的值是(-1, -1),是形状的中心。

  • 只有十字星型的形状与锚点位置紧密相关。在其他情况下,锚点位置仅用于形态学运算结果的调整。

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

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

import cv2 
kernel1 = cv2.getStructuringElement(cv2.MORPH_RECT, (5,5)) 
kernel2 = cv2.getStructuringElement(cv2.MORPH_CROSS,  (5,5)) 
kernel3 = cv2.getStructuringElement(cv2.MORPH_ELLIPSE,  (5,5)) 
print("kernel1=\n", kernel1) 
print("kernel2=\n", kernel2) 
print("kernel3=\n", kernel3) 

不同的核对形态学操作的影响:

import cv2 
o=cv2.imread("kernel.bmp", cv2.IMREAD_UNCHANGED) 
kernel1 = cv2.getStructuringElement(cv2.MORPH_RECT, (59,59)) 
kernel2 = cv2.getStructuringElement(cv2.MORPH_CROSS, (59,59)) 
kernel3 = cv2.getStructuringElement(cv2.MORPH_ELLIPSE, (59,59)) 
dst1 = cv2.dilate(o, kernel1) 
dst2 = cv2.dilate(o, kernel2) 
dst3 = cv2.dilate(o, kernel3)#膨胀 
cv2.imshow("orriginal", o) 
cv2.imshow("dst1", dst1) 
cv2.imshow("dst2", dst2) 
cv2.imshow("dst3", dst3) 
cv2.waitKey() 
cv2.destroyAllWindows() 
  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-05-08 08:05:07  更:2022-05-08 08:07:35 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/4 15:31:05-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码