#!/usr/bin/env python3
# -*- coding: utf-8 -*-

import numpy as np

from folder_locations import get_experiments_path

if __name__ == "__main__":
    in_experiment_path = get_experiments_path() / "2026-05-23_calc_AUDC_sensitivity_combined"
    in_results_path = in_experiment_path / "results"

    results_list = []
    for csv_path in in_results_path.glob("*.csv"):
        audc_steps_table = np.loadtxt(csv_path, delimiter = ",", skiprows=1, usecols=range(1, 7))
        print(f"{csv_path.name}, {audc_steps_table.shape}")
        #if audc_steps_table.shape[0] > 2:
        #    audc_steps_table = audc_steps_table[(0, 6),:]
        results_list.append(audc_steps_table)
    audc_steps_results = np.stack(results_list, axis=0)

    mean_audc_steps_results = np.mean(audc_steps_results, axis=0)

    #"""
    latex_names = [
        ("MMBS", 0),
        ("MMBS + SG", 4),
        ("IG", 1),
        ("IG + SG", 5),
        ("GIG (paper)", 2),
        ("GIG (paper) + SG", 6),
        ("GIG (Saliency)", 3),
        ("GIG (Saliency) + SG", 7),
        ("XRAI (B + W)", 8),
        ("XRAI (zero)", 9),
        ("GradCAM", 10)]
    """
    latex_names = [("MMBS", 0), ("GIG (paper) + SG", 1)]
    """

    for method_name, i in latex_names:
        method_line = method_name + " & "
        method_line += " & ".join([f"{mean_audc_steps_results[i,j]:0.3f}" for j in range(mean_audc_steps_results.shape[1])])
        method_line += f" & {mean_audc_steps_results[i,2]-mean_audc_steps_results[i,5]:0.5f}"
        method_line += r"\\"
        if i == len(latex_names)-1:
            method_line += r" \hline"
        print(method_line)