图片的腐蚀,膨胀,开丶闭运算,梯度计算,礼帽与黑帽
  4fj4wU5xgAdW 2023年11月02日 87 0

1 腐蚀操作

  用于图片的去毛刺,内容削减

  

 1 #腐蚀操作
 2 #cv2.erode(src,kernel,iterations) 
 3 #src是图片数字化数组
 4 #kernel则是一个盒,对该盒内的像素进行复试操作,值越小腐蚀能力越狠
 5 #iterations是一个迭代次数,就是说你对这个图片进行几次的腐蚀操作
 6 kernel = np.ones((30,30),np.uint8)
 7 erosion1 = cv2.erode(img,kernel,iterations=1)
 8 erosion2 = cv2.erode(img,kernel,iterations=2)
 9 erosion3 = cv2.erode(img,kernel,iterations=3)
10 res = np.hstack((erosion1,erosion2,erosion3))
11 Cv_Show('Erode Picture',res)

2 膨胀操作

 1 #膨胀操作 
 2 #因为在进行腐蚀操作后,原本不需要的腐蚀的地方会变细,此时可以通过膨胀操作加回来
 3 #cv2.dilate(src,kernel,iterations)
 4 #src是图像数字化数组
 5 #Kernel为盒,对该盒内的像素进行膨胀操作,值越小膨胀能力越强
 6 #iterations是一个迭代次数,就是说你对这个图片进行几次的膨胀操作
 7 kernel = np.ones((30,30),np.uint8)
 8 dilate1 = cv2.dilate(img,kernel,iterations=1)
 9 dilate2 = cv2.dilate(img,kernel,iterations=2)
10 dilate3 = cv2.dilate(img,kernel,iterations=3)
11 res = np.hstack((dilate1,dilate2,dilate3))
12 Cv_Show('Erode Picture',res)

3 开运算,闭运算

  

 1 #开运算就是先腐蚀后膨胀,闭运算是先膨胀后腐蚀
 2 #cv2.morphologyEx(src,type,kernel)
 3 #src是图像数字化数组
 4 #type有cv2.MORPH_OPEN,cv2.MORPH_CLOSE两种
 5 #cv2.MORPH_OPEN就是开运算
 6 #cv2.MORPH_CLOSE就是闭运算
 7 #Kernel为盒,对该盒内的像素进行膨胀操作,值越小膨胀能力越强
 8 kernel3 = np.ones((30,30),np.uint8)
 9 opening = cv2.morphologyEx(img,cv2.MORPH_OPEN,kernel3) #使用开运算
10 closeing = cv2.morphologyEx(img,cv2.MORPH_CLOSE,kernel3) #使用闭运算 
11 res = np.hstack((opening,closeing))
12 Cv_Show('morphologyEx Picture', res)

4 梯度运算

1 #梯度运算
2 #梯度 = 膨胀 - 腐蚀
3 #梯度运算是为了得到边界变化的信息
4 gradient = cv2.morphologyEx(img,cv2.MORPH_GRADIENT,kernel3)
5 Cv_Show('Gradient Picture', gradient)

5 礼帽与黑帽

1 #礼帽和黑帽
2 #礼帽 = 原始输入 - 开运算结果 从理论上来说,一个带毛刺的图片优化后没有毛刺 - 原始有毛刺的图,那结果是毛刺
3 #黑帽 = 闭运算 - 原始输入 同样,因为先对毛刺先膨胀后腐蚀,所以有些毛刺可能没腐蚀掉,减去原始后,结果是那些没腐蚀掉的毛刺的边缘
4 topHat = cv2.morphologyEx(img,cv2.MORPH_TOPHAT,kernel3)
5 blackHat = cv2.morphologyEx(img,cv2.MORPH_BLACKHAT,kernel3)
6 res = np.hstack((topHat,blackHat))
7 Cv_Show('TopHat vs BlackHat Picture', res)

 

【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年11月08日 0

暂无评论

推荐阅读
  2Fnpj8K6xSCR   2024年05月17日   100   0   0 Python
  xKQN3Agd2ZMK   2024年05月17日   70   0   0 Python
  fwjWaDlWXE4h   2024年05月17日   38   0   0 Python
  YpHJ7ITmccOD   2024年05月17日   39   0   0 Python
4fj4wU5xgAdW