-
Notifications
You must be signed in to change notification settings - Fork 10
/
demo_eval_lsp.m
60 lines (51 loc) · 1.87 KB
/
demo_eval_lsp.m
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
% LSP joint
% 1 Right ankle
% 2 Right knee
% 3 Right hip
% 4 Left hip
% 5 Left knee
% 6 Left ankle
% 7 Right wrist
% 8 Right elbow
% 9 Right shoulder
% 10 Left shoulder
% 11 Left elbow
% 12 Left wrist
% 13 Neck
% 14 Head top
startup;
reference_joints_pair = [3, 10]; % right shoulder and left hip (from observer's perspective)
% symmetry_joint_id(i) = j, if joint j is the symmetry joint of i (e.g., the left
% shoulder is the symmetry joint of the right shoulder).
symmetry_joint_id = [6,5,4,3,2,1,12,11,10,9,8,7,14,13];
joint_name = {'Ankle', 'Knee', 'Hip', 'Wris', 'Elbo', 'Shou', 'Head'};
% symmetry_part_id(i) = j, if part j is the symmetry part of i (e.g., the left
% upper arm is the symmetry part of the right upper arm).
symmetry_part_id = [4,3,2,1,8,7,6,5,9,10];
part_name = {'L.legs', 'U.legs', 'L.arms', 'U.arms', 'Head', 'Torso'};
%% Evaluate LSP (Observer Centric)
load('gt/lsp-joints-OC.mat', 'joints');
joints = joints(1:2,:,1001:end);
eval_name = 'LSP-OC';
% eval PCP
load('results/LSP/pred_sticks_lsp_oc.mat', 'pred');
gt_sticks = keypoints2sticks(joints);
eval_pcp(pred, gt_sticks, symmetry_part_id, part_name, eval_name);
% eval PCK
load('results/LSP/pred_keypoints_lsp_oc.mat', 'pred');
eval_pck(pred, joints, symmetry_joint_id, joint_name, eval_name);
% eval PDJ
eval_pdj(pred, joints, reference_joints_pair, symmetry_joint_id, joint_name, eval_name);
%% Evaluate LSP (Person Centric)
load('gt/lsp-joints-PC.mat', 'joints');
joints = joints(1:2,:,1001:end);
eval_name = 'LSP-PC';
% eval PCP
load('results/LSP/pred_sticks_lsp_pc.mat', 'pred');
gt_sticks = keypoints2sticks(joints);
eval_pcp(pred, gt_sticks, symmetry_part_id, part_name, eval_name);
% eval PCK
load('results/LSP/pred_keypoints_lsp_pc.mat', 'pred');
eval_pck(pred, joints, symmetry_joint_id, joint_name, eval_name);
% eval PDJ
eval_pdj(pred, joints, reference_joints_pair, symmetry_joint_id, joint_name, eval_name);