-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmdc_to_mask.py
118 lines (86 loc) · 3.37 KB
/
mdc_to_mask.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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
import cv2
from matplotlib import pyplot as plt
import numpy as np
from os import walk, sep
import argparse
def process(fpath: str, low=200, upper=255, verbose=False, iter=5, ksize=5):
img = cv2.imread(fpath)
if verbose:
plt.figure()
plt.imshow(img, cmap='gray')
plt.title('Original Img')
# in grayscale
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
# sogliatura e binarizzazione
_, thresh = cv2.threshold(gray, low, upper, cv2.THRESH_BINARY)
if verbose:
plt.figure()
plt.imshow(thresh, cmap='gray')
plt.title('Thresholded Img')
kernel = cv2.getStructuringElement(cv2.MORPH_ELLIPSE, (ksize, ksize))
thresh = cv2.medianBlur(thresh, ksize=5)
eroded = cv2.erode(thresh, kernel=kernel, iterations=iter)
# individuo le componenti connesse
totalLabels, label_ids, values, centroid = cv2.connectedComponentsWithStats(
eroded)
output = np.zeros(thresh.shape, dtype="uint8")
areas = []
# Loop through each component
for i in range(1, totalLabels):
area = values[i, cv2.CC_STAT_AREA]
x, y = thresh.shape
xc, yc = tuple(centroid[i])
diffx = abs(x / 2 - xc)
diffy = abs(y / 2 - yc)
areas.append((area, i, diffx + diffy))
# max_area, id = max(areas, key=lambda x: x[0])
_, id, _ = min(areas, key=lambda x: x[2])
# Labels stores all the IDs of the components on the each pixel
# It has the same dimension as the threshold
# So we'll check the component
# then convert it to 255 value to mark it white
componentMask = (label_ids == id).astype("uint8") * 255
# # Creating the Final output mask
output = cv2.bitwise_or(output, componentMask)
output = cv2.dilate(output, kernel=kernel, iterations=iter)
if verbose:
plt.figure()
plt.imshow(output, cmap='gray')
plt.title('Output Img')
return output
def main():
parser = argparse.ArgumentParser(
description='Generate Mask from MDC images')
parser.add_argument('source_dir', type=str, help='Original MDC images')
parser.add_argument('dest_dir',
type=str,
help='Folder where to store final results')
# Optional argument
parser.add_argument('--lower',
type=int,
default=190,
help='Color lower bound')
parser.add_argument('--upper',
type=int,
default=255,
help='Color upper bound')
parser.add_argument(
'--iter',
type=int,
default=2,
help='Number of times the OPENING operation is applied')
parser.add_argument('--ksize', type=int, default=5, help='Kernel size')
args = parser.parse_args()
for (dirpath, _, filenames) in walk(args.source_dir):
for filename in filenames:
if filename.endswith('.png'):
img_full_path = sep.join([dirpath, filename])
out_img = process(img_full_path,
args.lower,
args.upper,
iter=args.iter,
ksize=args.ksize)
cv2.imwrite(sep.join([args.dest_dir, f"MASK_{filename}"]),
out_img)
if __name__ == "__main__":
main()