-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathvisualization.py
executable file
·40 lines (36 loc) · 1.85 KB
/
visualization.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
import cv2
import os
from utils import normalize
import numpy as np
def visualizer(pathes, anomaly_map, img_size, save_path, cls_name):
for idx, path in enumerate(pathes):
cls = path.split('/')[-2]
filename = path.split('/')[-1]
vis = cv2.cvtColor(cv2.resize(cv2.imread(path), (img_size, img_size)), cv2.COLOR_BGR2RGB) # RGB
mask = normalize(anomaly_map[idx])
vis = apply_ad_scoremap(vis, mask)
vis = cv2.cvtColor(vis, cv2.COLOR_RGB2BGR) # BGR
save_vis = os.path.join(save_path, 'imgs', cls_name[idx], cls)
if not os.path.exists(save_vis):
os.makedirs(save_vis)
cv2.imwrite(os.path.join(save_vis, filename), vis)
def apply_ad_scoremap(image, scoremap, alpha=0.5):
np_image = np.asarray(image, dtype=float)
scoremap = (scoremap * 255).astype(np.uint8)
scoremap = cv2.applyColorMap(scoremap, cv2.COLORMAP_JET)
scoremap = cv2.cvtColor(scoremap, cv2.COLOR_BGR2RGB)
return (alpha * np_image + (1 - alpha) * scoremap).astype(np.uint8)
# def vis_stack(pathes, anomaly_map, img_size, save_path, cls_name):
# for idx, path in enumerate(pathes):
# for inner_idx, file in enumerate(sorted(os.listdir(path))):
# cls = path.split('/')[-3]
# rendering = path.split('/')[-2]
# filename = path.split('/')[-1]
# vis = cv2.cvtColor(cv2.resize(cv2.imread(os.path.join(path, file)), (img_size, img_size)), cv2.COLOR_BGR2RGB) # RGB
# mask = normalize(anomaly_map[inner_idx])
# vis = apply_ad_scoremap(vis, mask)
# vis = cv2.cvtColor(vis, cv2.COLOR_RGB2BGR) # BGR
# save_vis = os.path.join(save_path, 'imgs', cls_name[idx], cls, rendering, filename)
# if not os.path.exists(save_vis):
# os.makedirs(save_vis)
# cv2.imwrite(os.path.join(save_vis, file), vis)