-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathcifar10_data.py
38 lines (36 loc) · 1.22 KB
/
cifar10_data.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
import pickle
import numpy as np
import glob
def load_cifar10(dirpath='cifar-10-batches-py'):
# load training data
X, y = [], []
for path in glob.glob('%s/data_batch_*' % dirpath):
with open(path, 'rb') as f:
batch = pickle.load(f)
X.append(batch['data'])
y.append(batch['labels'])
X = np.concatenate(X) \
.reshape(-1, 3, 32, 32) \
.astype(np.float32)
y = np.concatenate(y).astype(np.int32)
# split into training and validation sets
ii = np.random.permutation(len(X))
X_train = X[ii[1000:]]
y_train = y[ii[1000:]]
X_valid = X[ii[:1000]]
y_valid = y[ii[:1000]]
# load test set
path = '%s/test_batch' % dirpath
with open(path, 'rb') as f:
batch = pickle.load(f)
X_test = batch['data'] \
.reshape(-1, 3, 32, 32) \
.astype(np.float32)
y_test = np.array(batch['labels'], dtype=np.int32)
# normalize to zero mean and unity variance
offset = np.mean(X_train, 0)
scale = np.std(X_train, 0).clip(min=1)
X_train = (X_train - offset) / scale
X_valid = (X_valid - offset) / scale
X_test = (X_test - offset) / scale
return X_train, y_train, X_valid, y_valid, X_test, y_test