腐蚀和膨胀是最基本的形态学操作,腐蚀和膨胀都是针对白色部分(高亮部分)而言的。
用一个结构元素扫描图像中的每一个像素,用结构元素中的每一个像素与其覆盖的对应像素做“与"操 作,如果都为1,则该像素为1,否则为0。如下图所示,结构A被结构B腐蚀后:
cv.erode(img,kernel,iterations)
用一个结构元素扫描图像中的每一个像羹,用结构元素中的每一个像素与其覆盖的对应像素做 “与"操作,如果都为0,则该像素为0,否则为1。如下图所示,结构A被结构B膨胀后:
cv.dilate(img,kernel,iterations)
import numpy as np
import cv2 as cv
img = cv.imread("./img/1.jpg")
# 创建核结构
kernel = np.ones((5,5),np.uint8)
# 腐蚀和膨胀
erosion = cv.erode(img,kernel) #腐蚀
dilate = cv.dilate(img,kernel) #膨胀
cv2.imshow('1', img) # 原图
cv2.imshow('2', erosion) # 腐蚀后
cv2.imshow('3', dilate) # 膨胀后
开运算和闭运算是将腐蚀和膨胀按照一定的次序进行处理。但这两者并不是可逆的,即先开后闭(先闭后开)并不能得到原来的图像。
函数:cv.morphologyEx(img, op, kernel)
import numpy as np
import cv2 as cv
import matplotlib.pyplot as plt
img = cv.imread("./img/1.jpg")
# 创建核结构
kernel = np.ones((5,5),np.uint8)
#图像的开闭运算
cvOPen = cv.morphologyEx(img,cv.MORPH_OPEN,kernel) #开运算
cvClose = cv.morphologyEx(img,cv.MORPH_CLOSE,kernel) #闭运算
#图像展示
fig,axes=plt.subplots(nrows=1,ncols=3,figsize=(15, 10))
axes[0].imshow(img[:,:,::-1]), axes[0].set_title("原图")
axes[1].imshow(cvOPen[:,:,::-1]), axes[1].set_title("开运算")
axes[2].imshow(cvClose[:,:,::-1]), axes[2].set_title("闭运算")
plt.show()
原图像与开运算结果之差,如下式计算:
d s t = t o p h a t ( s r c , e l e m e n t ) = s r c − o p e n ( s r c , e l e m e n t ) dst = tophat(src, element) = src - open(src, element) dst=tophat(src,element)=src−open(src,element)
由于开运算可能会放大了裂缝或者局部低亮度的区域。
“闭运算“的结果图与原图像之差,如下式计算:
d s t = b l a c k h a t ( s r c , e l e m e n t ) = c l o s e ( s r c , e l e m e n t ) − s r c dst = blackhat(src, element) = close(src, element) - src dst=blackhat(src,element)=close(src,element)−src
黑帽运算后的效果图突出了比原图轮廓周围的区域更暗的区域,且这一操作和选择的核的大小相关。
黑帽运算可以用来分离比邻近点暗一些的斑块。
cv.morphologyEx(img, op, kernel)
参数:
img:要处理的图像
op:处理方式
闭运算:cv.MORPH_CLOSE
开运算:cv.MORPH_OPEN
礼帽运算:cv.MORPH_TOPHAT
黑帽运算:cv.MORPH_BLACKHAT
Kernel:核结构
【1】https://blog.csdn.net/qq_50620084/article/details/124526983