forked from breadbread1984/c3d
-
Notifications
You must be signed in to change notification settings - Fork 0
/
create_dataset.py
105 lines (100 loc) · 3.46 KB
/
create_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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
#!/usr/bin/python
# -*- coding: utf-8 -*-
import cv2;
import numpy as np;
from numpy.random import uniform;
from random import shuffle;
import os;
import tensorflow as tf;
import pickle;
def video2sample(ucf_rootdir):
if False == os.path.exists(ucf_rootdir) or False == os.path.isdir(ucf_rootdir):
print "invalid UCF root directory!";
exit(1);
dirs = [d for d in os.listdir(ucf_rootdir)];
classname = dict();
samplelist = list();
#collect all samples
for i in range(0,len(dirs)):
dirname = dirs[i];
if True == os.path.isdir(os.path.join(ucf_rootdir,dirname)):
classname[i] = dirname;
videos = [v for v in os.listdir(os.path.join(ucf_rootdir,dirname))];
#for every video
for j in range(0,len(videos)):
vidname = videos[j];
name,ext = os.path.splitext(vidname);
if ext == '.avi' or ext == '.AVI':
vp = os.path.join(ucf_rootdir,dirname,vidname);
samplelist.append((vp,i));
i = i + 1;
#output id->classname map to file
with open('id2classname.dat','w') as f:
f.write(pickle.dumps(classname));
#shuffle samples
shuffle(samplelist);
trainset_size = 9 * len(samplelist) / 10;
#write all train samples to tfrecord
if True == os.path.exists('trainset.tfrecord'):
os.remove('trainset.tfrecord');
writer = tf.python_io.TFRecordWriter('trainset.tfrecord');
for sample in samplelist[0:trainset_size]:
cap = cv2.VideoCapture(sample[0]);
if False == cap.isOpened():
print sample[0] + " can't be opened!";
continue;
features = np.zeros((16,112,112,3),dtype = np.uint8);
count = 0;
while True:
#stride = 32, therefore skip 16 frames after every 16 frames for training samples
if count == 16:
trainsample = tf.train.Example(features = tf.train.Features(
feature = {
'clips': tf.train.Feature(bytes_list = tf.train.BytesList(value = [features.tobytes()])),
'label': tf.train.Feature(int64_list = tf.train.Int64List(value = [sample[1]]))
}
));
writer.write(trainsample.SerializeToString());
#copy the last 8 frames to first 8 frame position of features[]
features[0:8,...] = features[8:16,...];
count = 8;
ret,frame = cap.read();
if False == ret:
break;
frame = cv2.resize(frame,(160,120))[4:116,24:136];
features[count,...] = frame;
count = count + 1;
writer.close();
#write all test samples to tfrecord
if True == os.path.exists('testset.tfrecord'):
os.remove('testset.tfrecord');
writer = tf.python_io.TFRecordWriter('testset.tfrecord');
for sample in samplelist[trainset_size:]:
cap = cv2.VideoCapture(sample[0]);
if False == cap.isOpened():
print sample[0] + " can't be opened!";
continue;
features = np.zeros((16,112,112,3),dtype = np.uint8);
count = 0;
while True:
#stride = 32, therefore skip 16 frames after every 16 frames for training samples
if count == 16:
trainsample = tf.train.Example(features = tf.train.Features(
feature = {
'clips': tf.train.Feature(bytes_list = tf.train.BytesList(value = [features.tobytes()])),
'label': tf.train.Feature(int64_list = tf.train.Int64List(value = [sample[1]]))
}
));
writer.write(trainsample.SerializeToString());
#copy the last 8 frames to first 8 frame position of features[]
features[0:8,...] = features[8:16,...];
count = 8;
ret,frame = cap.read();
if False == ret:
break;
frame = cv2.resize(frame,(160,120))[4:116,24:136];
features[count,...] = frame;
count = count + 1;
writer.close();
if __name__ == "__main__":
video2sample('/home/sys411/tmp/UCF-101/');