-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathGray-Scale-Erosion-Dilation-Morpholgical-Operation-Without-Build-in.py
62 lines (62 loc) · 1.96 KB
/
Gray-Scale-Erosion-Dilation-Morpholgical-Operation-Without-Build-in.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
import cv2 as cv
import numpy as np
# padding
def padding(originalImg, padSize):
padImg = np.zeros((rows+2*padSize, columns+2*padSize), dtype=np.uint8)
# Slicing
padImg[padSize:rows+padSize, padSize:columns+padSize] = originalImg
return padImg
def GrayErosion(padImg, kernel, size):
output = np.zeros((rows, columns), dtype=np.uint8)
for i in range(0, rows):
for j in range(0, columns):
# Slicing
portion = padImg[i:i+size, j:j+size]
portion1 = portion.flatten()
portion2 = kernel.flatten()
# sum of Kernel and window
p1 = (np.sum(portion1))
p2 = (np.sum(portion2))*255
# if Fit Condition Satisfies
if p1 == p2:
output[i, j] = 255
else:
output[i, j] = np.min(portion1)
return output
def GrayDilation(padImg, size):
output = np.zeros((rows, columns), dtype=np.uint8)
for i in range(0, rows):
for j in range(0, columns):
# Slicing
portion = padImg[i:i+size, j:j+size]
portion1 = portion.flatten()
# if Hit Condition Satisfies
if 255 in portion1:
output[i, j] = 255
else:
output[i, j] = np.max(portion1)
return output
size = 3
# Structuring Element
kernel = np.ones((size, size), np.uint8)
# padding size
p_size = size//2
# image reading
orginalImg = cv.imread('headCT-Vandy.tif', 0)
# getting size of image
rows = orginalImg.shape[0]
columns = orginalImg.shape[1]
# padding function call
padImg = padding(orginalImg, p_size)
# Erotion
Erode = GrayErosion(padImg, kernel, size)
cv.imshow('output2', Erode)
cv.waitKey(0)
# Dilation
Dilate = GrayDilation(padImg, size)
cv.imshow('output3', Dilate)
cv.waitKey(0)
# Morphological Gradient
MorphologicalGradient = Dilate - Erode
cv.imshow('output4', MorphologicalGradient)
cv.waitKey(0)