forked from RyanZotti/Self-Driving-Car
-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathwindowed_dataset.py
47 lines (38 loc) · 1.57 KB
/
windowed_dataset.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
import numpy as np
import random
input_file_path = '/Users/ryanzotti/Documents/repos/Self_Driving_RC_Car/final_processed_data_3_channels.npz'
npzfile = np.load(input_file_path)
# training data
train_predictors = npzfile['train_predictors']
train_targets = npzfile['train_targets']
def shuffle_dataset(predictors, targets):
record_count = predictors.shape[0]
shuffle_index = np.arange(record_count)
np.random.shuffle(shuffle_index)
predictors = predictors[shuffle_index]
targets = targets[shuffle_index]
return predictors, targets
def window(batch_index,batch_size,window_size,predictors,targets):
frame_index = batch_size * batch_index
windowed_predictors = []
windowed_targets = []
for record_index in range(batch_size):
frame_index += record_index
windowed_predictors.append(predictors[frame_index:frame_index + window_size])
windowed_targets.append(targets[frame_index + window_size])
windowed_predictors = np.array(windowed_predictors)
windowed_targets = np.array(windowed_targets)
windowed_predictors, windowed_targets = shuffle_dataset(windowed_predictors,windowed_targets)
'''
for record_index in range(batch_size):
for frame_index, frame in enumerate(windowed_predictors[record_index]):
cv2.imshow('frame', frame)
print()
if cv2.waitKey(1) & 0xFF == ord('q'):
break
'''
return windowed_predictors, windowed_targets
# 15.83, 23.57
batch_index = 0
predictors, target = window(batch_index, 50, 50, train_predictors, train_targets)
print('test')