-
Notifications
You must be signed in to change notification settings - Fork 185
/
Evaluate_Anomaly_Detector.m
118 lines (87 loc) · 3.39 KB
/
Evaluate_Anomaly_Detector.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
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
118
clc
clear all
close all
C3D_CNN_Path='/home/cvlab/Waqas_Data/Anomaly_Data/C3D_Complete_video/Testing_Videos_C3D'; % C3D features for videos
Testing_VideoPath='/home/cvlab/Waqas_Data/Anomaly_Data/Testing_Videos'; % Path of mp4 videos
AllAnn_Path='/home/cvlab/Waqas_Data/Anomaly_Data/Temporal_Annotations'; % Path of Temporal Annotations
Model_Score_Folder='/home/cvlab/Waqas_Data/Anomaly_Data/Model_Res'; % Path of Pretrained Model score on Testing videos (32 numbers for 32 temporal segments)
Paper_Results='/home/cvlab/Waqas_Data/Anomaly_Data/Eval_Res'; % Path to save results.
All_Videos_scores=dir(Model_Score_Folder);
All_Videos_scores=All_Videos_scores(3:end);
nVideos=length(All_Videos_scores);
frm_counter=1;
All_Detect=zeros(1,1000000);
All_GT=zeros(1,1000000);
for ivideo=1:nVideos
ivideo
Ann_Path=[AllAnn_Path,'/',All_Videos_scores(ivideo).name(1:end-4),'.mat'];
load(Ann_Path)
check=strmatch(All_Videos_scores(ivideo).name(1:end-6),Testing_Videos1.name(1:end-3));
if isempty(check)
error('????')
end
VideoPath=[Testing_VideoPath,'/', All_Videos_scores(ivideo).name(1:end-4),'.mp4'];
ScorePath=[Model_Score_Folder,'/', All_Videos_scores(ivideo).name(1:end-4),'.mat'];
%% Load Video
try
xyloObj = VideoReader(VideoPath);
catch
error('???')
end
Predic_scores=load(ScorePath);
fps=30;
Actual_frames=round(xyloObj.Duration*fps);
Folder_Path=[C3D_CNN_Path,'/',All_Videos_scores(ivideo).name(1:end-4)];
AllFiles=dir([Folder_Path,'/*.fc6-1']);
nFileNumbers=length(AllFiles);
nFrames_C3D=nFileNumbers*16; % As the features were computed for every 16 frames
%% 32 Shots
Detection_score_32shots=zeros(1,nFrames_C3D);
Thirty2_shots= round(linspace(1,length(AllFiles),33));
Shots_Features=[];
p_c=0;
for ishots=1:length(Thirty2_shots)-1
p_c=p_c+1;
ss=Thirty2_shots(ishots);
ee=Thirty2_shots(ishots+1)-1;
if ishots==length(Thirty2_shots)
ee=Thirty2_shots(ishots+1);
end
if ee<ss
Detection_score_32shots((ss-1)*16+1:(ss-1)*16+1+15)=Predic_scores.predictions(p_c);
else
Detection_score_32shots((ss-1)*16+1:(ee-1)*16+16)=Predic_scores.predictions(p_c);
end
end
Final_score= [Detection_score_32shots,repmat(Detection_score_32shots(end),[1,Actual_frames-length(Detection_score_32shots)])];
GT=zeros(1,Actual_frames);
for ik=1:size(Testing_Videos1.Ann,1)
st_fr=max(Testing_Videos1.Ann(ik,1),1);
end_fr=min(Testing_Videos1.Ann(ik,2),Actual_frames);
GT(st_fr:end_fr)=1;
end
if Testing_Videos1.Ann(1,1)==0.05 % For Normal Videos
GT=zeros(1,Actual_frames);
end
% Final_score= ones(1,length(Final_score));
% subplot(2,1,1); bar(Final_score)
% subplot(2,1,2); bar(GT)
All_Detect(frm_counter:frm_counter+length(Final_score)-1)=Final_score;
All_GT(frm_counter:frm_counter+length(Final_score)-1)=GT;
frm_counter=frm_counter+length(Final_score);
end
All_Detect=(All_Detect(1:frm_counter-1));
All_GT=All_GT(1:frm_counter-1);
scores=All_Detect;
[so,si] = sort(scores,'descend');
tp=All_GT(si)>0;
fp=All_GT(si)==0;
tp=cumsum(tp);
fp=cumsum(fp);
nrpos=sum(All_GT);
rec=tp/nrpos;
fpr=fp/sum(All_GT==0);
prec=tp./(fp+tp);
AUC1 = trapz(fpr ,rec );
% You can also use the following codes
%[X,Y,T,AUC] = perfcurve(All_GT,All_Detect,1);