function eval_tracker(seqs, trackers, eval_type, name_tracker_all, tmp_mat_path, path_anno, rp_all, norm_dst)
% evaluate each tracker
num_tracker = numel(trackers);

threshold_set_overlap = 0:0.05:1;
threshold_set_error   = 0:50;
if norm_dst
    threshold_set_error = threshold_set_error / 100;
end

improveNUM = 0;
decreaseNUM = 0;

for i = 1:numel(seqs) % for each sequence
    s = seqs{i};      % name of sequence
    
    % load GT and the absent flags
    %     anno        = dlmread([path_anno 'gt_rect/' s '.txt']);
    %     absent_anno = dlmread([path_anno 'absent/' s '.txt']);
    
    anno             = dlmread([path_anno s '/groundtruth.txt']);
    absent_anno = dlmread([path_anno s '/absent.txt']);
    absent_anno = 1 - absent_anno; 
    
    %     meanIOU_track1 = 0;
    %     meanIOU_track2 = 0;
    %     meanIOU_track3 = 0;
    
    for k = 1:num_tracker  % evaluate each tracker
        t = trackers{k};   % name of tracker
        % load tracking result 
        
        res = dlmread([rp_all t.name '_tracking_result/' s '.txt']);
%         try
%             res = dlmread([rp_all t.name '_tracking_result/' s '.txt']);
%         catch
%             try
%                 res = dlmread([rp_all t.name '_tracking_result/results' s '.txt']);
%             catch
%                 res = dlmread([rp_all t.name '_tracking_result/' s '_001.txt']);
%             end
%         end
        fprintf(['evaluating ' t.name ' on ' s ' ...\n']);
        
        success_num_overlap = zeros(1, numel(threshold_set_overlap));
        success_num_err     = zeros(1, numel(threshold_set_error));
        
        if isempty(res)
            break;
        end
        
        [err_coverage, err_center] = calc_seq_err_robust(res, anno, absent_anno, norm_dst);
        
        %% for rebuttal
        meanIOU = sum(err_coverage) / size(err_coverage, 1);
        
        %         if k==1, meanIOU_track1 = meanIOU; end
        %         if k==2, meanIOU_track2 = meanIOU; end
        %         if k==3, meanIOU_track3 = meanIOU; end
        
        for t_idx = 1:numel(threshold_set_overlap)
            success_num_overlap(1, t_idx) = sum(err_coverage > threshold_set_overlap(t_idx));
        end
        
        for t_idx = 1:length(threshold_set_error)
            success_num_err(1, t_idx) = sum(err_center <= threshold_set_error(t_idx));
        end
        
        len_all = size(anno, 1);  % number of frames in the sequence
        
        ave_success_rate_plot(k, i, :)     = success_num_overlap/(len_all + eps);
        ave_success_rate_plot_err(k, i, :) = success_num_err/(len_all + eps);
    end
    
    %     if meanIOU_track3 > meanIOU_track2
    %         improveNUM = improveNUM + 1;
    %     else
    %         decreaseNUM = decreaseNUM + 1;
    %     end
    
end

% disp(['==>> improvePercent: ', num2str(improveNUM/315)]);
% disp(['==>> decreaseNUM: ', num2str(decreaseNUM/315)]);

% save results
if ~exist(tmp_mat_path, 'dir')
    mkdir(tmp_mat_path);
end

dataName1 = [tmp_mat_path 'aveSuccessRatePlot_' num2str(num_tracker) 'alg_overlap_' eval_type '.mat'];
save(dataName1, 'ave_success_rate_plot', 'name_tracker_all');

dataName2 = [tmp_mat_path 'aveSuccessRatePlot_' num2str(num_tracker) 'alg_error_' eval_type '.mat'];
ave_success_rate_plot = ave_success_rate_plot_err;
save(dataName2, 'ave_success_rate_plot', 'name_tracker_all');

end





