mirror of
https://github.com/TheAlgorithms/Python.git
synced 2025-01-18 00:07:00 +00:00
Add median filter algorithm (#675)
This commit is contained in:
parent
2d70e9f747
commit
ac28125060
0
digital_image_processing/__init__.py
Normal file
0
digital_image_processing/__init__.py
Normal file
0
digital_image_processing/filters/__init__.py
Normal file
0
digital_image_processing/filters/__init__.py
Normal file
42
digital_image_processing/filters/median_filter.py
Normal file
42
digital_image_processing/filters/median_filter.py
Normal file
|
@ -0,0 +1,42 @@
|
|||
"""
|
||||
Implementation of median filter algorithm
|
||||
"""
|
||||
|
||||
from cv2 import imread, cvtColor, COLOR_BGR2GRAY, imshow, waitKey
|
||||
from numpy import zeros_like, ravel, sort, multiply, divide, int8
|
||||
|
||||
|
||||
def median_filter(gray_img, mask=3):
|
||||
"""
|
||||
:param gray_img: gray image
|
||||
:param mask: mask size
|
||||
:return: image with median filter
|
||||
"""
|
||||
# set image borders
|
||||
bd = int(mask / 2)
|
||||
# copy image size
|
||||
median_img = zeros_like(gray)
|
||||
for i in range(bd, gray_img.shape[0] - bd):
|
||||
for j in range(bd, gray_img.shape[1] - bd):
|
||||
# get mask according with mask
|
||||
kernel = ravel(gray_img[i - bd:i + bd + 1, j - bd:j + bd + 1])
|
||||
# calculate mask median
|
||||
median = sort(kernel)[int8(divide((multiply(mask, mask)), 2) + 1)]
|
||||
median_img[i, j] = median
|
||||
return median_img
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
# read original image
|
||||
img = imread('lena.jpg')
|
||||
# turn image in gray scale value
|
||||
gray = cvtColor(img, COLOR_BGR2GRAY)
|
||||
|
||||
# get values with two different mask size
|
||||
median3x3 = median_filter(gray, 3)
|
||||
median5x5 = median_filter(gray, 5)
|
||||
|
||||
# show result images
|
||||
imshow('median filter with 3x3 mask', median3x3)
|
||||
imshow('median filter with 5x5 mask', median5x5)
|
||||
waitKey(0)
|
Loading…
Reference in New Issue
Block a user