-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbIoU.py
406 lines (395 loc) · 15.5 KB
/
bIoU.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
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
import numpy as np
import os
from PIL import Image
import cv2
# annotations
gt_path = "/home/data/ADE20K/annotations/validation"
# path to masks with all categories
pred_path = "/home/TASFormer/ADE20K_multitask_segmentation/results/adapter_150_640"
num_classes = 150
# 12
categories_ade_12=[
"other",
"building;edifice",
"sky",
"floor;flooring",
"tree",
"bed",
"windowpane;window",
"person;individual;someone;somebody;mortal;soul",
"door;double;door",
"table",
"chair",
"car;auto;automobile;machine;motorcar",
"bicycle;bike;wheel;cycle"
]
categories_ade_2=[
"other",
"building;edifice",
"floor;flooring",
]
categories_ade=[
"other", "wall", "building;edifice", "sky", "floor;flooring", "tree", "ceiling", "road;route", "bed",
"windowpane;window", "grass", "cabinet", "sidewalk;pavement", "person;individual;someone;somebody;mortal;soul",
"earth;ground", "door;double;door", "table", "mountain;mount", "plant;flora;plant;life", "curtain;drape;drapery;mantle;pall",
"chair", "car;auto;automobile;machine;motorcar", "water", "painting;picture", "sofa;couch;lounge", "shelf",
"house","sea", "mirror", "rug;carpet;carpeting", "field", "armchair", "seat", "fence;fencing", "desk",
"rock;stone", "wardrobe;closet;press", "lamp", "bathtub;bathing;tub;bath;tub", "railing;rail", "cushion",
"base;pedestal;stand", "box", "column;pillar", "signboard;sign", "chest;of;drawers;chest;bureau;dresser", "counter",
"sand", "sink", "skyscraper", "fireplace;hearth;open;fireplace", "refrigerator;icebox", "grandstand;covered;stand",
"path", "stairs;steps", "runway", "case;display;case;showcase;vitrine", "pool;table;billiard;table;snooker;table",
"pillow", "screen;door;screen", "stairway;staircase", "river", "bridge;span", "bookcase", "blind;screen",
"coffee;table;cocktail;table", "toilet;can;commode;crapper;pot;potty;stool;throne", "flower", "book",
"hill", "bench", "countertop", "stove;kitchen;stove;range;kitchen;range;cooking;stove", "palm;palm;tree",
"kitchen;island", "computer;computing;machine;computing;device;data;processor;electronic;computer;information;processing;system",
"swivel;chair", "boat", "bar", "arcade;machine", "hovel;hut;hutch;shack;shanty", "bus;autobus;coach;charabanc;double-decker;jitney;motorbus;motorcoach;omnibus;passenger;vehicle",
"towel", "light;light;source", "truck;motortruck", "tower", "chandelier;pendant;pendent", "awning;sunshade;sunblind", "streetlight;street;lamp", "booth;cubicle;stall;kiosk", "television;television;receiver;television;set;tv;tv;set;idiot;box;boob;tube;telly;goggle;box", "airplane;aeroplane;plane", "dirt;track",
"apparel;wearing;apparel;dress;clothes", "pole", "land;ground;soil", "bannister;banister;balustrade;balusters;handrail", "escalator;moving;staircase;moving;stairway",
"ottoman;pouf;pouffe;puff;hassock", "bottle", "buffet;counter;sideboard", "poster;posting;placard;notice;bill;card",
"stage", "van", "ship", "fountain", "conveyer;belt;conveyor;belt;conveyer;conveyor;transporter", "canopy",
"washer;automatic;washer;washing;machine", "plaything;toy", "swimming;pool;swimming;bath;natatorium", "stool",
"barrel;cask", "basket;handbasket", "waterfall;falls", "tent;collapsible;shelter", "bag", "minibike;motorbike", "cradle",
"oven", "ball", "food;solid;food", "step;stair", "tank;storage;tank", "trade;name;brand;name;brand;marque",
"microwave;microwave;oven", "pot;flowerpot", "animal;animate;being;beast;brute;creature;fauna", "bicycle;bike;wheel;cycle",
"lake", "dishwasher;dish;washer;dishwashing;machine", "screen;silver;screen;projection;screen", "blanket;cover",
"sculpture", "hood;exhaust;hood", "sconce", "vase", "traffic;light;traffic;signal;stoplight", "tray",
"ashcan;trash;can;garbage;can;wastebin;ash;bin;ash-bin;ashbin;dustbin;trash;barrel;trash;bin", "fan",
"pier;wharf;wharfage;dock", "crt;screen", "plate", "monitor;monitoring;device", "bulletin;board;notice;board",
"shower", "radiator", "glass;drinking;glass", "clock", "flag"
]
cat_mapping_ade_12={
'background': 'other',
'wall': 'other',
'building;edifice': 'building;edifice',
'sky': 'sky',
'floor;flooring': 'floor;flooring',
'tree': 'tree',
'ceiling': 'other',
'road;route': 'other',
'bed': 'bed',
'windowpane;window': 'windowpane;window',
'grass': 'other',
'cabinet': 'other',
'sidewalk;pavement': 'other',
'person;individual;someone;somebody;mortal;soul': 'person;individual;someone;somebody;mortal;soul',
'earth;ground': 'other',
'door;double;door': 'door;double;door',
'table': 'table',
'mountain;mount': 'other',
'plant;flora;plant;life': 'other',
'curtain;drape;drapery;mantle;pall': 'other',
'chair': 'chair',
'car;auto;automobile;machine;motorcar': 'car;auto;automobile;machine;motorcar',
'water': 'other',
'painting;picture': 'other',
'sofa;couch;lounge': 'other',
'shelf': 'other',
'house': 'other',
'sea': 'other',
'mirror': 'other',
'rug;carpet;carpeting': 'other',
'field': 'other',
'armchair': 'other',
'seat': 'other',
'fence;fencing': 'other',
'desk': 'other',
'rock;stone': 'other',
'wardrobe;closet;press': 'other',
'lamp': 'other',
'bathtub;bathing;tub;bath;tub': 'other',
'railing;rail': 'other',
'cushion': 'other',
'base;pedestal;stand': 'other',
'box': 'other',
'column;pillar': 'other',
'signboard;sign': 'other',
'chest;of;drawers;chest;bureau;dresser': 'other',
'counter': 'other',
'sand': 'other',
'sink': 'other',
'skyscraper': 'other',
'fireplace;hearth;open;fireplace': 'other',
'refrigerator;icebox': 'other',
'grandstand;covered;stand': 'other',
'path': 'other',
'stairs;steps': 'other',
'runway': 'other',
'case;display;case;showcase;vitrine': 'other',
'pool;table;billiard;table;snooker;table': 'other',
'pillow': 'other',
'screen;door;screen': 'other',
'stairway;staircase': 'other',
'river': 'other',
'bridge;span': 'other',
'bookcase': 'other',
'blind;screen': 'other',
'coffee;table;cocktail;table': 'other',
'toilet;can;commode;crapper;pot;potty;stool;throne': 'other',
'flower': 'other',
'book': 'other',
'hill': 'other',
'bench': 'other',
'countertop': 'other',
'stove;kitchen;stove;range;kitchen;range;cooking;stove': 'other',
'palm;palm;tree': 'other',
'kitchen;island': 'other',
'computer;computing;machine;computing;device;data;processor;electronic;computer;information;processing;system': 'other',
'swivel;chair': 'other',
'boat': 'other',
'bar': 'other',
'arcade;machine': 'other',
'hovel;hut;hutch;shack;shanty': 'other',
'bus;autobus;coach;charabanc;double-decker;jitney;motorbus;motorcoach;omnibus;passenger;vehicle': 'other',
'towel': 'other',
'light;light;source': 'other',
'truck;motortruck': 'other',
'tower': 'other',
'chandelier;pendant;pendent': 'other',
'awning;sunshade;sunblind': 'other',
'streetlight;street;lamp': 'other',
'booth;cubicle;stall;kiosk': 'other',
'television;television;receiver;television;set;tv;tv;set;idiot;box;boob;tube;telly;goggle;box': 'other',
'airplane;aeroplane;plane': 'other',
'dirt;track': 'other',
'apparel;wearing;apparel;dress;clothes': 'other',
'pole': 'other',
'land;ground;soil': 'other',
'bannister;banister;balustrade;balusters;handrail': 'other',
'escalator;moving;staircase;moving;stairway': 'other',
'ottoman;pouf;pouffe;puff;hassock': 'other',
'bottle': 'other',
'buffet;counter;sideboard': 'other',
'poster;posting;placard;notice;bill;card': 'other',
'stage': 'other',
'van': 'other',
'ship': 'other',
'fountain': 'other',
'conveyer;belt;conveyor;belt;conveyer;conveyor;transporter': 'other',
'canopy': 'other',
'washer;automatic;washer;washing;machine': 'other',
'plaything;toy': 'other',
'swimming;pool;swimming;bath;natatorium': 'other',
'stool': 'other',
'barrel;cask': 'other',
'basket;handbasket': 'other',
'waterfall;falls': 'other',
'tent;collapsible;shelter': 'other',
'bag': 'other',
'minibike;motorbike': 'other',
'cradle': 'other',
'oven': 'other',
'ball': 'other',
'food;solid;food': 'other',
'step;stair': 'other',
'tank;storage;tank': 'other',
'trade;name;brand;name;brand;marque': 'other',
'microwave;microwave;oven': 'other',
'pot;flowerpot': 'other',
'animal;animate;being;beast;brute;creature;fauna': 'other',
'bicycle;bike;wheel;cycle': 'bicycle;bike;wheel;cycle',
'lake': 'other',
'dishwasher;dish;washer;dishwashing;machine': 'other',
'screen;silver;screen;projection;screen': 'other',
'blanket;cover': 'other',
'sculpture': 'other',
'hood;exhaust;hood': 'other',
'sconce': 'other',
'vase': 'other',
'traffic;light;traffic;signal;stoplight': 'other',
'tray': 'other',
'ashcan;trash;can;garbage;can;wastebin;ash;bin;ash-bin;ashbin;dustbin;trash;barrel;trash;bin': 'other',
'fan': 'other',
'pier;wharf;wharfage;dock': 'other',
'crt;screen': 'other',
'plate': 'other',
'monitor;monitoring;device': 'other',
'bulletin;board;notice;board': 'other',
'shower': 'other',
'radiator': 'other',
'glass;drinking;glass': 'other',
'clock': 'other',
'flag': 'other',
}
cat_mapping_ade_2={
'background': 'other',
'wall': 'other',
'building;edifice': 'building;edifice',
'sky': 'other',
'floor;flooring': 'floor;flooring',
'tree': 'other',
'ceiling': 'other',
'road;route': 'other',
'bed': 'other',
'windowpane;window': 'other',
'grass': 'other',
'cabinet': 'other',
'sidewalk;pavement': 'other',
'person;individual;someone;somebody;mortal;soul': 'other',
'earth;ground': 'other',
'door;double;door': 'other',
'table': 'other',
'mountain;mount': 'other',
'plant;flora;plant;life': 'other',
'curtain;drape;drapery;mantle;pall': 'other',
'chair': 'other',
'car;auto;automobile;machine;motorcar': 'other',
'water': 'other',
'painting;picture': 'other',
'sofa;couch;lounge': 'other',
'shelf': 'other',
'house': 'other',
'sea': 'other',
'mirror': 'other',
'rug;carpet;carpeting': 'other',
'field': 'other',
'armchair': 'other',
'seat': 'other',
'fence;fencing': 'other',
'desk': 'other',
'rock;stone': 'other',
'wardrobe;closet;press': 'other',
'lamp': 'other',
'bathtub;bathing;tub;bath;tub': 'other',
'railing;rail': 'other',
'cushion': 'other',
'base;pedestal;stand': 'other',
'box': 'other',
'column;pillar': 'other',
'signboard;sign': 'other',
'chest;of;drawers;chest;bureau;dresser': 'other',
'counter': 'other',
'sand': 'other',
'sink': 'other',
'skyscraper': 'other',
'fireplace;hearth;open;fireplace': 'other',
'refrigerator;icebox': 'other',
'grandstand;covered;stand': 'other',
'path': 'other',
'stairs;steps': 'other',
'runway': 'other',
'case;display;case;showcase;vitrine': 'other',
'pool;table;billiard;table;snooker;table': 'other',
'pillow': 'other',
'screen;door;screen': 'other',
'stairway;staircase': 'other',
'river': 'other',
'bridge;span': 'other',
'bookcase': 'other',
'blind;screen': 'other',
'coffee;table;cocktail;table': 'other',
'toilet;can;commode;crapper;pot;potty;stool;throne': 'other',
'flower': 'other',
'book': 'other',
'hill': 'other',
'bench': 'other',
'countertop': 'other',
'stove;kitchen;stove;range;kitchen;range;cooking;stove': 'other',
'palm;palm;tree': 'other',
'kitchen;island': 'other',
'computer;computing;machine;computing;device;data;processor;electronic;computer;information;processing;system': 'other',
'swivel;chair': 'other',
'boat': 'other',
'bar': 'other',
'arcade;machine': 'other',
'hovel;hut;hutch;shack;shanty': 'other',
'bus;autobus;coach;charabanc;double-decker;jitney;motorbus;motorcoach;omnibus;passenger;vehicle': 'other',
'towel': 'other',
'light;light;source': 'other',
'truck;motortruck': 'other',
'tower': 'other',
'chandelier;pendant;pendent': 'other',
'awning;sunshade;sunblind': 'other',
'streetlight;street;lamp': 'other',
'booth;cubicle;stall;kiosk': 'other',
'television;television;receiver;television;set;tv;tv;set;idiot;box;boob;tube;telly;goggle;box': 'other',
'airplane;aeroplane;plane': 'other',
'dirt;track': 'other',
'apparel;wearing;apparel;dress;clothes': 'other',
'pole': 'other',
'land;ground;soil': 'other',
'bannister;banister;balustrade;balusters;handrail': 'other',
'escalator;moving;staircase;moving;stairway': 'other',
'ottoman;pouf;pouffe;puff;hassock': 'other',
'bottle': 'other',
'buffet;counter;sideboard': 'other',
'poster;posting;placard;notice;bill;card': 'other',
'stage': 'other',
'van': 'other',
'ship': 'other',
'fountain': 'other',
'conveyer;belt;conveyor;belt;conveyer;conveyor;transporter': 'other',
'canopy': 'other',
'washer;automatic;washer;washing;machine': 'other',
'plaything;toy': 'other',
'swimming;pool;swimming;bath;natatorium': 'other',
'stool': 'other',
'barrel;cask': 'other',
'basket;handbasket': 'other',
'waterfall;falls': 'other',
'tent;collapsible;shelter': 'other',
'bag': 'other',
'minibike;motorbike': 'other',
'cradle': 'other',
'oven': 'other',
'ball': 'other',
'food;solid;food': 'other',
'step;stair': 'other',
'tank;storage;tank': 'other',
'trade;name;brand;name;brand;marque': 'other',
'microwave;microwave;oven': 'other',
'pot;flowerpot': 'other',
'animal;animate;being;beast;brute;creature;fauna': 'other',
'bicycle;bike;wheel;cycle': 'other',
'lake': 'other',
'dishwasher;dish;washer;dishwashing;machine': 'other',
'screen;silver;screen;projection;screen': 'other',
'blanket;cover': 'other',
'sculpture': 'other',
'hood;exhaust;hood': 'other',
'sconce': 'other',
'vase': 'other',
'traffic;light;traffic;signal;stoplight': 'other',
'tray': 'other',
'ashcan;trash;can;garbage;can;wastebin;ash;bin;ash-bin;ashbin;dustbin;trash;barrel;trash;bin': 'other',
'fan': 'other',
'pier;wharf;wharfage;dock': 'other',
'crt;screen': 'other',
'plate': 'other',
'monitor;monitoring;device': 'other',
'bulletin;board;notice;board': 'other',
'shower': 'other',
'radiator': 'other',
'glass;drinking;glass': 'other',
'clock': 'other',
'flag': 'other',
}
iou_scores_gt = []
for idx, gt_filename in enumerate(os.listdir(gt_path)):
#gt_filename = "ADE_val_00000001.png"
gt_mask = np.array(Image.open(f"{gt_path}/{gt_filename}"))
gt_mask = gt_mask.astype(np.int64)
gt_idx = gt_filename.split(".")[0]
for cat in range(1, 150+1):
gt = gt_mask == cat
if num_classes == 12:
gt_cat_name = categories_ade[cat]
pred_cat_name = cat_mapping_ade_12[gt_cat_name]
pred_cat_idx = categories_ade_12.index(pred_cat_name)-1
if num_classes == 2:
gt_cat_name = categories_ade[cat]
pred_cat_name = cat_mapping_ade_2[gt_cat_name]
pred_cat_idx = categories_ade_2.index(pred_cat_name)-1
if num_classes == 150:
pred_cat_idx = cat-1
if np.sum(gt) > 0 and pred_cat_idx >= 0:
pred = np.array(Image.open(f"{pred_path}/{gt_idx}_{pred_cat_idx}.png"))
pred = cv2.resize(pred, dsize=(gt.shape[1], gt.shape[0]), interpolation=cv2.INTER_NEAREST)
pred = pred.astype(bool)
intersection = np.logical_and(gt, pred)
union = np.logical_or(gt, pred)
iou_score = np.sum(intersection) / np.sum(union)
iou_scores_gt.append(iou_score)
#input()
print("Done: ", idx)
print("Mean IoU GT:", np.mean(iou_scores_gt))
print("Mean IoU GT:", np.mean(iou_scores_gt))