• Opencv形态学——腐蚀、膨胀、开运算与闭运算、梯度运算、礼帽、黑帽


    引言

    形态学是基于图像形状的基础变换,一般情况下对二值图像上做处理。需要输入两个参数:一、输入原始图像;二、结构化元素或核,决定操作性质。

    一、腐蚀(Erosion)

    操作原理:当内核下的所有像素都为1时,原始图像中的像素(要么为1,要么为0)才会被认为是1,否则会被腐蚀为零。所以腐蚀之后的结果取决于内核的大小,迭代的次数不同结果也会不同。

    1. import matplotlib.pyplot as plt
    2. import cv2
    3. import numpy as np
    4. def cv_show(name,img):
    5. cv2.imshow(name,img)
    6. cv2.waitKey(0)
    7. cv2.destroyAllWindows()
    8. i=cv2.imread("C:/birdtemplet.bmp")
    9. kernel=np.ones((5,5),np.uint8)
    10. crosion=cv2.erode(i,kernel,iterations=2)
    11. crosion1=cv2.erode(i,kernel,iterations=4)
    12. i_1=np.hstack((i,crosion,crosion1))
    13. cv_show('i_1',i_1)

    iterations代表迭代的次数。结果如图所示:

    二、 膨胀 Dilation

    膨胀是腐蚀的逆运算。它增加了图像中的白色区域,或者说增加了前景目标对象的尺寸大小。通常情况下,在腐蚀操作后就是膨胀操作。因为,腐蚀消除了白色的·噪音,但也缩小了前景图,所以我们要扩大它。

    1. kernel=np.ones((5,5),np.uint8)
    2. crosion=cv2.erode(i,kernel,iterations=2)
    3. kernel=np.ones((5,5),np.uint8)
    4. dilate=cv2.dilate(i,kernel,iterations=2)
    5. i_2=np.hstack((i,crosion,dilate))
    6. cv_show('i_2',i_2)

    结果显示为原图,腐蚀图,膨胀图:

    三、开运算 

     先进行腐蚀,再进行膨胀叫做开运算。 通常情况下,含有噪声的图像二值化后,得到的边界是不平滑的,物体区域具有一些错判的孔洞,就要用到开运算。

    1. opening=cv2.morphologyEx(i,cv2.MORPH_OPEN,kernel)
    2. cv_show('opening',opening)

    结果如图所示:

    四、闭运算

    先膨胀再腐蚀。

    1. closing=cv2.morphologyEx(i,cv2.MORPH_CLOSE,kernel)
    2. cv_show('closing',closing)

    结果如图所示:

    五、梯度运算(膨胀—腐蚀=梯度)

    1. gradient=cv2.morphologyEx(i,cv2.MORPH_GRADIENT,kernel)
    2. cv_show('gradient',gradient)

    结果如图所示:

     六、礼帽(原始输入-开运算结果)

    1. tophat=cv2.morphologyEx(i,cv2.MORPH_TOPHAT,kernel)
    2. i_3=np.hstack((i,opening,tophat))
    3. cv_show('i_3',i_3)

    结果如图所示:

     七、黑帽(闭运算-原始输入)

    1. blackhat=cv2.morphologyEx(i,cv2.MORPH_BLACKHAT,kernel)
    2. i_4=np.hstack((i,closing,blackhat))
    3. cv_show('i_4',i_4)

     结果如图所示:

  • 相关阅读:
    【首阳首板之主升三域主升域】揭开主升路径奥秘,驾驭主升
    关于redis的一主三从三哨兵的实现
    64_Pandas进行字符串和数字的相互转换和格式化
    面向对象程序设计关于Lua的初识之类
    windows:批处理bat入门
    筹备三年,自动驾驶L3标准将至,智驾产业链的关键一跃
    ctfshow web入门(2)
    鞋子,靴子,拖鞋傻傻分不清楚 pytorch实现分类 入门小案例
    HummerRisk V0.5.2:升级对象存储、云检测、云审计和K8s资源态势等
    Windows环境编译webots遇到报错:‘gbk‘ codec can‘t decode byte 0x93 in position 547
  • 原文地址:https://blog.csdn.net/m0_72662900/article/details/126680077