%% tracker performance evaluation tool for FELT Benchmark
% (modified based on LaSOT toolkit by Xiao Wang)
% 10/01/2022

clc; clear all; close all; warning off;

addpath('./utils/');
addpath('./sequence_evaluation_config/');

%% Used for BOC score evaluation 
load('./aveSuccessRatePlot_15alg_overlap_OPE.mat'); 
average_SR_value = mean(ave_success_rate_plot, 3); 
average_video_reward = 1 - mean(average_SR_value, 1); 

tmp_mat_path  = './tmp_mat/';          % path to save temporary results
path_anno     = './annos/felt_anno/';                  % path to annotations
path_att      = './annos/att/';               % path to attribute
rp_all        = './felt_tracking_results/';        % path to tracking results
save_fig_path = './res_fig/';                 % path to result figures
save_fig_suf  = 'png';                          % suffix of figures, 'png' or 'eps'

att_name      = {'Fast Motion', 'Viewpoint Transformation', 'Deformation', ...
    'Full Occlusion', 'Low Illumination', 'Out-of-View', 'Partial Occlusion', ...
     'Scale Variation', 'Background Influence', ...
    'Aspect Ration Change', 'No Motion', ...
    'Illumination Variation', 'Over Exposure', 'Small Traget' };

att_fig_name  = {'FM','VT', 'DEF', 'FOC', 'LI ', 'OV', 'POC' , 'SV', 'BI', 'ARC', 'NMO', 'IV' , 'OE', 'ST'};

% 'test_set' --- evaluation the whole test set
evaluation_dataset_type = 'test_set';

% use normalization or not
norm_dst = false;

trackers      = config_tracker();
sequences  = config_sequence(evaluation_dataset_type);
plot_style   = config_plot_style();

num_seq = numel(sequences);
num_tracker = numel(trackers);

% load tracker info
name_tracker_all = cell(num_tracker, 1);
for i = 1:num_tracker
    name_tracker_all{i} = trackers{i}.name;
end

% load sequence info
% name_seq_all = cell(num_seq, 1);
% for i = 1:num_seq
%     name_seq_all{i} = sequences{i};
%     
%     seq_att = importdata(fullfile(path_att, [sequences{i} '.txt']));
%     
%     if i == 1
%         att_all = zeros(num_seq, numel(seq_att));
%     end
%     sequences{i}
%     att_all(i, :) = seq_att;
% end

% parameters for evaluation
metric_type_set = {'error', 'overlap'};
eval_type       = 'OPE';
% ranking_type    = 'threshold';
ranking_type    = 'AUC';   % change it to 'AUC' for success plots
rank_num = 50;
% draw the results under each challenging factors or not?
drawAttributeResults = false; %% true, false





threshold_set_error   = 0:50;
if norm_dst
    threshold_set_error = threshold_set_error / 100;
end
threshold_set_overlap = 0:0.05:1;

for i = 1:numel(metric_type_set)
    % error (for distance plots) or overlap (for success plots)
    metric_type = metric_type_set{i};
    switch metric_type
        case 'error'
            threshold_set = threshold_set_error;
            rank_idx      = 21;
            x_label_name  = 'Location error threshold';
            y_label_name  = 'Precision';
        case 'overlap'
            threshold_set = threshold_set_overlap;
            rank_idx      = 11;
            x_label_name  = 'Overlap threshold';
            y_label_name  = 'Success rate';
    end
    
    if strcmp(metric_type, 'error') && strcmp(ranking_type, 'AUC') % for ranking_type = 'AUC'
        %     if strcmp(metric_type, 'overlap') && strcmp(ranking_type, 'threshold')  % for ranking_type = 'threshold'
        continue;
    end
    
    t_num = numel(threshold_set);
    
    % we only use OPE for evaluation
    plot_type = [metric_type '_' eval_type];
    
    switch metric_type
        case 'error'
            title_name = ['Precision plots of ' eval_type];
            if norm_dst
                title_name = ['Normalized ' title_name];
            end
            
            if strcmp(evaluation_dataset_type, 'all')
                title_name = [title_name ' on FELT'];
            else
                title_name = [title_name ' on FELT Testing Set'];
            end
        case 'overlap'
            title_name = ['Success plots of ' eval_type];
            
            if strcmp(evaluation_dataset_type, 'all')
                title_name = [title_name ' on FELT'];
            else
                title_name = [title_name ' on FELT Testing Set'];
            end
    end
    
    dataName = [tmp_mat_path 'aveSuccessRatePlot_' num2str(num_tracker) 'alg_'  plot_type '.mat'];
    
    % evaluate tracker performance
    eval_tracker(sequences, trackers, eval_type, name_tracker_all, tmp_mat_path, path_anno, rp_all, norm_dst);
    
    %% for BOC score 
    load('.\tmp_mat\aveSuccessRatePlot_29alg_overlap_OPE.mat')
    mean_ave_success_rate_plot = mean(ave_success_rate_plot, 3); 
    if size(mean_ave_success_rate_plot, 1) ~= size(average_video_reward, 1)
        expanded_average_video_reward = repmat(average_video_reward, size(mean_ave_success_rate_plot, 1) ); 
    end 
    expanded_average_video_reward = expanded_average_video_reward(:, 1:size(average_video_reward, 2)); 
    
    BOC_score_all =  mean_ave_success_rate_plot .* expanded_average_video_reward; 
    BOC_score = mean(BOC_score_all, 2); 
    %  Stem Figure 
    figure; 
    stem(BOC_score, 'LineWidth', 2); 
    %     title('BOC Score', 'fontsize', font_size);
    xlim([0 size(BOC_score, 1)+1]) 
    set(gca, 'XTick', [1:1:size(BOC_score, 1)])
    set(gca, 'XTickLabel', {name_tracker_all{1, 1}, name_tracker_all{2, 1}, name_tracker_all{3, 1}, name_tracker_all{4, 1}, name_tracker_all{5, 1}, name_tracker_all{6, 1}, name_tracker_all{7, 1}, name_tracker_all{8, 1}, name_tracker_all{9, 1}, name_tracker_all{10, 1}, name_tracker_all{11, 1}, name_tracker_all{12, 1}, name_tracker_all{13, 1}, name_tracker_all{14, 1}, name_tracker_all{15, 1},  name_tracker_all{16, 1}, name_tracker_all{17, 1}, name_tracker_all{18, 1}, name_tracker_all{19, 1}, name_tracker_all{20, 1}, name_tracker_all{21, 1}, name_tracker_all{22, 1}, name_tracker_all{23, 1}, name_tracker_all{24, 1}, name_tracker_all{25, 1}, name_tracker_all{26, 1}, name_tracker_all{27, 1}, name_tracker_all{28, 1}, name_tracker_all{29, 1} })
    set(gca, 'XTickLabelRotation', -45); 
    %     xlabel('Tracker Index', 'fontsize', 14);
    ylabel('BOC Score', 'fontsize', 14);
    grid on; 
    
    % plot performance
    load(dataName);
    num_tracker = size(ave_success_rate_plot, 1);
    
    if rank_num > num_tracker || rank_num <0
        rank_num = num_tracker;
    end
    
    fig_name= [plot_type '_' ranking_type];
    idx_seq_set = 1:numel(sequences);
    
    
    
    
    %%%%%% draw and save the overall performance plot
    plot_draw_save(num_tracker, plot_style, ave_success_rate_plot, ...
        idx_seq_set, rank_num, ranking_type, rank_idx, ...
        name_tracker_all, threshold_set, title_name, ...
        x_label_name, y_label_name, fig_name, save_fig_path, ...
        save_fig_suf);
    
    
    
    %%%%% draw and save the per-attribute performance plot
    if drawAttributeResults
        att_trld = 0;
        att_num  = size(att_all, 2);
        for att_idx = 1:att_num    % for each attribute
            idx_seq_set = find(att_all(:, att_idx) > att_trld);
            if length(idx_seq_set) < 2
                continue;
            end
            disp([att_name{att_idx} ' ' num2str(length(idx_seq_set))]);
            
            fig_name   = [att_fig_name{att_idx} '_'  plot_type '_' ranking_type];
            title_name = ['Plots of ' eval_type ': ' att_name{att_idx} ' (' num2str(length(idx_seq_set)) ')'];
            
            switch metric_type
                case 'overlap'
                    title_name = ['Success plots of ' eval_type ' - ' att_name{att_idx} ' (' num2str(length(idx_seq_set)) ')'];
                case 'error'
                    title_name = ['Precision plots of ' eval_type ' - ' att_name{att_idx} ' (' num2str(length(idx_seq_set)) ')'];
                    if norm_dst
                        title_name = ['Normalized ' title_name];
                    end
            end
            
            plot_draw_save(num_tracker, plot_style, ave_success_rate_plot, ...
                idx_seq_set, rank_num, ranking_type, rank_idx, ...
                name_tracker_all, threshold_set, title_name, ...
                x_label_name, y_label_name, fig_name, save_fig_path, ...
                save_fig_suf);
        end
        
    end
    
end



