-
Notifications
You must be signed in to change notification settings - Fork 36
/
Copy pathcamvid_data_loader.py
63 lines (48 loc) · 1.59 KB
/
camvid_data_loader.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
from __future__ import absolute_import
from __future__ import print_function
import cv2
import numpy as np
import itertools
from helper import *
import os
# Copy the data to this dir here in the SegNet project /CamVid from here:
# https://github.com/alexgkendall/SegNet-Tutorial
DataPath = './CamVid/'
data_shape = 360*480
def load_data(mode):
data = []
label = []
with open(DataPath + mode +'.txt') as f:
txt = f.readlines()
txt = [line.split(' ') for line in txt]
for i in range(len(txt)):
data.append(np.rollaxis(normalized(cv2.imread(os.getcwd() + txt[i][0][7:])),2))
label.append(one_hot_it(cv2.imread(os.getcwd() + txt[i][1][7:][:-1])[:,:,0]))
print('.',end='')
return np.array(data), np.array(label)
train_data, train_label = load_data("train")
train_label = np.reshape(train_label,(367,data_shape,12))
test_data, test_label = load_data("test")
test_label = np.reshape(test_label,(233,data_shape,12))
val_data, val_label = load_data("val")
val_label = np.reshape(val_label,(101,data_shape,12))
np.save("data/train_data", train_data)
np.save("data/train_label", train_label)
np.save("data/test_data", test_data)
np.save("data/test_label", test_label)
np.save("data/val_data", val_data)
np.save("data/val_label", val_label)
# FYI they are:
# Sky = [128,128,128]
# Building = [128,0,0]
# Pole = [192,192,128]
# Road_marking = [255,69,0]
# Road = [128,64,128]
# Pavement = [60,40,222]
# Tree = [128,128,0]
# SignSymbol = [192,128,128]
# Fence = [64,64,128]
# Car = [64,0,128]
# Pedestrian = [64,64,0]
# Bicyclist = [0,128,192]
# Unlabelled = [0,0,0]