forked from stevenwudi/chalearn2014_wudi_lio
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Step4_compute_test_state_matrix.py
76 lines (63 loc) · 2.75 KB
/
Step4_compute_test_state_matrix.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
from glob import glob
import os
import sys
import cPickle
from classes import GestureSample
from functions.preproc_functions import *
from functions.test_functions import *
from functions.test_cnn_build import build
from classes.hyperparameters import batch
import scipy.io as sio
## Load Prior and transitional Matrix
dic=sio.loadmat('Prior_Transition_matrix_5states.mat')
Transition_matrix = dic['Transition_matrix']
Prior = dic['Prior']
#data path and store path definition
pc = "wudi"
if pc=="wudi":
src_dir = r"I:\Kaggle_multimodal\Test_CNN_precompute_TEST"
save_dst = r"I:\Kaggle_multimodal\Precompute_state_matrix_TEST"
elif pc=="lio":
data = r"/media/lio/Elements/chalearn/trainingset"
load_flag = True
os.chdir(src_dir)
if pc=="wudi":
samples=glob("*") # because wudi unzipped all the files already!
elif pc=="lio":
samples=glob("*.zip")
print len(samples), "samples found"
# compile test functions
evalu_model, x_ = build()
print "finish compiling......"
for file_count, file in enumerate(samples):
condition = (file_count > -1)
if condition: #wudi only used first 650 for validation !!! Lio be careful!
print("\t Processing file " + file)
# Create the object to access the sample
load_path = os.path.join(src_dir,file)
video = cPickle.load(open(load_path,"rb"))
print video.shape
print "start computing likelihood"
observ_likelihood = numpy.empty(shape=(video.shape[0],20*5+1)) # 20 classed * 5 states + 1 ergodic state
for batchnumber in xrange(video.shape[0]/batch.micro):
video_temp = video[batch.micro*batchnumber:batch.micro*(batchnumber+1),:]
x_.set_value(video_temp.astype("float32"),borrow=True)
y_pred, p_y_given_x = evalu_model()
observ_likelihood[batch.micro*batchnumber:batch.micro*(batchnumber+1),:] = \
p_y_given_x
# because input batch number should be 64, so here it is a bit of hack:
video_temp_1 = video[batch.micro* (batchnumber+1):,:]
video_temp_2 = numpy.zeros(shape=(64-video_temp_1.shape[0], 2, 2, 4, 64, 64))
video_temp = numpy.concatenate((video_temp_1, video_temp_2), axis=0)
x_.set_value(video_temp.astype("float32"),borrow=True)
y_pred, p_y_given_x = evalu_model()
observ_likelihood[batch.micro* (batchnumber+1):,:] = \
p_y_given_x[:video_temp_1.shape[0], :]
##########################
# save state matrix
#####################
save_path= os.path.join(save_dst, file)
out_file = open(save_path, 'wb')
cPickle.dump(observ_likelihood, out_file, protocol=cPickle.HIGHEST_PROTOCOL)
out_file.close()
# combine: 0.810069759331, sk: 0.769519406566, cnn: 0.716777803623