import os
import numpy as np
import matplotlib.pyplot as plt
import skimage.io as sio
np.set_printoptions(threshold=np.nan, linewidth=10000)
label_path = '/temp_disk/xs/sun/train/label/'
csv_path = '/temp_disk/xs/sun/seg37_class_dict.csv'
def get_label_info(csv_path):
# return label -> {label_name: [r_value, g_value, b_value, ...}
ann = pd.read_csv(csv_path)
label = {}
for iter, row in ann.iterrows():
label_name = row['name']
r = row['r']
g = row['g']
b = row['b']
if r + g + b == 0: # remove bg
continue
label[label_name] = [int(r), int(g), int(b)]
return label
def one_hot_it(label, label_info):
# return semantic_map -> [H, W, num_classes] (530, 730, 38)
semantic_map = []
for info in label_info:
color = label_info[info]
# colour_map = np.full((label.shape[0], label.shape[1], label.shape[2]), colour, dtype=int)
equality = np.equal(label, color)
class_map = np.all(equality, axis=-1)
semantic_map.append(class_map)
semantic_map = np.stack(semantic_map, axis=-1)
return semantic_map
label_info = get_label_info(csv_path)
label_names = list(label_info.keys())
for label in os.listdir(label_path):
label = sio.imread(label_path + label)
plt.imshow(label)
plt.show()
label = np.array(label)
label = one_hot_it(label, label_info).astype(np.uint8)
for i in range(len(label_names)): # classes
if np.sum(label[:, :, i]) > 0:
print(label_names[i], i)
mask = label[:, :, i] # class superpixel
plt.imshow(mask, cmap='gray')
plt.title(label_names[i])
plt.show()
break
wall 0
floor 1
door 7
window 8
paper 25
data:image/s3,"s3://crabby-images/e6344/e63446c5543a45a064b387ed63c49202df357a0f" alt=""
label color
data:image/s3,"s3://crabby-images/f9249/f9249c1091fd7c6aacbed292b7971f40de783a78" alt=""
wall
data:image/s3,"s3://crabby-images/53dcf/53dcfde32781d8ec0ee182381f6ebca30583b580" alt=""
floor
data:image/s3,"s3://crabby-images/77bd5/77bd59b147f2da29d7efaf5ae6397ac7bc61acc8" alt=""
door
data:image/s3,"s3://crabby-images/9ca74/9ca7487cffaf1cba85e0006295ba941395217253" alt=""
window
data:image/s3,"s3://crabby-images/fa723/fa7238ba5e4be85d61b2b8a17c34c4e9a878eb24" alt=""
paper
网友评论