跳转到内容

闭运算

维基百科,自由的百科全书

这是闭运算当前版本,由Shizhao留言 | 贡献编辑于2022年6月14日 (二) 01:44 (Shizhao移动页面Closing (形態學)闭运算。这个网址是本页该版本的固定链接。

(差异) ←上一修订 | 最后版本 (差异) | 下一修订→ (差异)
如果選擇灰色圓盤當 B(kernel),對兩個深藍色的正方形做closing,會多出淺藍色的部分.

在數學形態學中,集合B對集合A的Closing是先dilation再用erosion。

分别表示dilation和erosion。

在影像處理中,closing和opening是用來對影像除噪,這邊通常A就是我們輸入的影像,B則是kernel。

特性

[编辑]
  • Idempotent,即 .
  • Increasing,如果 , 然後 .
  • Extensive,即 .
  • Translation invariant.

實作

[编辑]

這邊對binary image做closing的操作,kernel為5*5大小,4個角落被去掉。

closing不一定要先dilation一次再用erosion一次,也可以使用closing = dilation k times + erosion k times。

當想要closing的洞比較大時,可以使用更高的k次。

def dilation(img):
  img1 = np.zeros((img.shape[0], img.shape[1]), dtype="int")
  for i in range(img.shape[0]):
    for j in range(img.shape[1]):
      if img[i][j]>0:
        row = i-2; col = j-2; # The octogonal 4-5-5-5-4 kernel
        for w in range(5):
          for h in range(5):
            if ( w==0 and h==0 ) or ( w==0 and h==4 ) or ( w==4 and h==0 ) or ( w==4 and h==4 ):
              continue
            else:
              i2 = row + w; j2 = col + h;
              if i2 >= 0 and j2 >= 0 and i2 < img.shape[0] and j2 < img.shape[1]:
                img1[i2][j2] = 255
  return img1

def erosion(img):
  img1 = np.zeros((img.shape[0], img.shape[1]), dtype="int")
  for i in range(img.shape[0]):
    for j in range(img.shape[1]):
        flag = 0
        row = i-2; col = j-2; # The octogonal 4-5-5-5-4 kernel
        for w in range(5):
          for h in range(5):
            if ( w==0 and h==0 ) or ( w==0 and h==4 ) or ( w==4 and h==0 ) or ( w==4 and h==4 ):
              continue
            else:
              i2 = row + w; j2 = col + h;
              if i2 > 0 and j2 > 0 and i2 < img.shape[0] and j2 < img.shape[1]:
                if img[i2][j2] == 0:
                  flag = 1
        if flag == 0:
          img1[i][j] = 255
  return img1
  
def closing(img):
  return erosion(dilation(img))

參考

[编辑]
  • Image Analysis and Mathematical Morphology by Jean Serra, ISBN 0-12-637240-3 (1982)
  • Image Analysis and Mathematical Morphology, Volume 2: Theoretical Advances by Jean Serra, ISBN 0-12-637241-1 (1988)
  • An Introduction to Morphological Image Processing by Edward R. Dougherty, ISBN 0-8194-0845-X (1992)