
clear;
s = '.';
class =[];
class_pred=[];
result =[];

%% Load the stored evaluation data.
for j=0
     ss = dir(sprintf('pretrained/setting/model%d/',j));
     [epoch{j+1},name{j+1},maxx(j+1)] = find_last(ss);
end
        
for j=0
  val = [];
  auc=[];
  auc_cvv=[];
  cc = name{j+1};
  for k=1:length(cc)
            try
            load(sprintf('pretrained/setting/model%d/%s',j,cc{k}));
            val(k) =-sum(class_train.*log(class_train_pred + 10^-10) + (1-class_train).*log(1-class_train_pred + 10^-10)); 
            auc(k)    = auc_test;
            auc_cvv(k) = auc_cv;
            catch
                continue;
            end 
            
  end
   % Find the epoch that gives the best results over validation set.
   [~,ind] = max(auc);
   save('checkpoint_original.mat','ind');
end

function [id,name,max] = find_last(ss)
n = size(ss);
max = 0 ;
tt=1;
id=[];
for i =3:n
    cc = ss(i).name;
    if cc(1:3)=='vis'    
     temp = str2num(cc(4:end-4));
     id = [id,temp];
     name{tt} = cc;
     tt = tt+1;
     if temp>max
     max = temp;
     end

    end
    
end

[id,ind]= sort(id,'ascend');
name = name(ind);

end