-
Notifications
You must be signed in to change notification settings - Fork 252
/
eval_full.py
117 lines (96 loc) · 4.31 KB
/
eval_full.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
106
107
108
109
110
111
112
113
114
115
116
117
#
# ColorHandPose3DNetwork - Network for estimating 3D Hand Pose from a single RGB Image
# Copyright (C) 2017 Christian Zimmermann
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#
""" Script for evaluation of the full pipeline.
This allows to reproduce results of Figure 9. But in order to do so you need to get the STB dataset.
See README for more information.
Results for STB-e:
Average mean EPE: 12.210 mm
Average median EPE: 9.405 mm
Area under curve: 0.764 (from 0mm to 50mm)
Area under curve: 0.941 (from 30mm to 50mm)
Results for RHD-e (not in the paper, but a possible baseline for future approaches):
Average mean EPE: 35.606 mm
Average median EPE: 28.686 mm
Area under curve: 0.424 (from 0mm to 50mm)
Area under curve: 0.603 (from 30mm to 50mm)
"""""
from __future__ import print_function, unicode_literals
import tensorflow as tf
import numpy as np
from data.BinaryDbReader import *
from data.BinaryDbReaderSTB import *
from nets.ColorHandPose3DNetwork import ColorHandPose3DNetwork
from utils.general import EvalUtil, get_stb_ref_curves, calc_auc
# get dataset
# dataset = BinaryDbReader(mode='evaluation', shuffle=False, use_wrist_coord=False)
dataset = BinaryDbReaderSTB(mode='evaluation', shuffle=False, use_wrist_coord=False)
# build network graph
data = dataset.get()
image_scaled = tf.image.resize_images(data['image'], (240, 320))
# build network
net = ColorHandPose3DNetwork()
# feed through network
evaluation = tf.placeholder_with_default(True, shape=())
_, _, _, _, _, coord3d_pred = net.inference(image_scaled, data['hand_side'], evaluation)
coord3d_gt = data['keypoint_xyz21']
# Start TF
gpu_options = tf.GPUOptions(per_process_gpu_memory_fraction=0.8)
sess = tf.Session(config=tf.ConfigProto(gpu_options=gpu_options))
tf.train.start_queue_runners(sess=sess)
# initialize network with weights used in the paper
net.init(sess, weight_files=['./weights/handsegnet-rhd.pickle',
'./weights/posenet3d-rhd-stb.pickle'])
util = EvalUtil()
# iterate dataset
for i in range(dataset.num_samples):
# get prediction
keypoint_xyz21, keypoint_vis21, keypoint_scale, coord3d_pred_v = sess.run([data['keypoint_xyz21'], data['keypoint_vis21'], data['keypoint_scale'], coord3d_pred])
keypoint_xyz21 = np.squeeze(keypoint_xyz21)
keypoint_vis21 = np.squeeze(keypoint_vis21)
coord3d_pred_v = np.squeeze(coord3d_pred_v)
keypoint_scale = np.squeeze(keypoint_scale)
# rescale to meters
coord3d_pred_v *= keypoint_scale
# center gt
keypoint_xyz21 -= keypoint_xyz21[0, :]
util.feed(keypoint_xyz21, keypoint_vis21, coord3d_pred_v)
if (i % 100) == 0:
print('%d / %d images done: %.3f percent' % (i, dataset.num_samples, i*100.0/dataset.num_samples))
# Output results
mean, median, auc, pck_curve_all, threshs = util.get_measures(0.0, 0.050, 20) # rainier: Should lead to 0.764 / 9.405 / 12.210
print('Evaluation results')
print('Average mean EPE: %.3f mm' % (mean*1000))
print('Average median EPE: %.3f mm' % (median*1000))
print('Area under curve between 0mm - 50mm: %.3f' % auc)
# only use subset that lies in 20mm .. 50mm
pck_curve_all, threshs = pck_curve_all[8:], threshs[8:]*1000.0
auc_subset = calc_auc(threshs, pck_curve_all)
print('Area under curve between 20mm - 50mm: %.3f' % auc_subset)
# Show Figure 9 from the paper
if type(dataset) == BinaryDbReaderSTB:
import matplotlib.pyplot as plt
curve_list = get_stb_ref_curves()
curve_list.append((threshs, pck_curve_all, 'Ours (AUC=%.3f)' % auc_subset))
fig = plt.figure()
ax = fig.add_subplot(111)
for t, v, name in curve_list:
ax.plot(t, v, label=name)
ax.set_xlabel('threshold in mm')
ax.set_ylabel('PCK')
plt.legend(loc='lower right')
plt.show()