Computer Vision/opencv(python)

[22] 2)블러링-평균값 필터

jwjwvison 2021. 3. 19. 13:42
  • 평균 값 필터 (Mean filter)
    • 영상의 특정 좌표 값을 주변 픽셀 값들의 산술 평균으로 설정
    • 픽셀들 간의 그레이스케일 값 변화가 줄어들어 날카로운 에지가 무뎌지고, 영상에 있는 잡음의 영향이 사라지는 효과

 

  • 실제 영상에 평균 값 필터를 적용한 결과

  • filter2D() 함수를 이용한 평균값 필터링 예제
import sys
import numpy as np
import cv2

src=cv2.imread('rose.bmp',cv2.IMREAD_GRAYSCALE)

if src is None:
    print('Image load failed!')
    sys.exit()

# kernel=np.array([[1/9,1/9,1/9,],[1/9,1/9,1/9,],[1/9,1/9,1/9,]],dtype=np.float32)

kernel=np.ones((3,3),dtype=np.float64)/9.
dst=cv2.filter2D(src,-1,kernel)

cv2.imshow('src',src)
cv2.imshow('dst',dst)
cv2.waitKey()
cv2.destroyAllWindows()

 

  • 평균 값 필터링 함수
cv2.blur(src,ksize,dst=None,anchor=None,borderType=None) -> dst

 • src: 입력 영상
 • ksize: 평균값 필터 크기. (width, height) 형태의 튜플.
 • dst: 결과 영상. 입력 영상과 같은 크기 & 같은 타입.

 

  • 다양한 크기의 커널을 사용한 평균값 필터링 예제
import sys
import numpy as np
import cv2

src = cv2.imread('rose.bmp', cv2.IMREAD_GRAYSCALE)

if src is None:
    print('Image load failed!')
    sys.exit()

cv2.imshow('src', src)

for ksize in (3, 5, 7):
    dst = cv2.blur(src, (ksize, ksize))

    desc = 'Mean: {}x{}'.format(ksize, ksize)
    cv2.putText(dst, desc, (10, 30), cv2.FONT_HERSHEY_SIMPLEX,
                1.0, 255, 1, cv2.LINE_AA)

    cv2.imshow('dst', dst)
    cv2.waitKey()

cv2.destroyAllWindows()