import os

import argparse
import pandas as pd
import numpy as np
import matplotlib.pyplot as plt

parser = argparse.ArgumentParser(description='')

parser.add_argument('dataset', type=str, help='dataset')
parser.add_argument('sigma_certify_file', type=str, help='sigma certify file')
parser.add_argument('class_certify_file', type=str, help='class certify file')
parser.add_argument('sigma_list', type=float, nargs='+', default=[0.25, 0.5, 1.0],
                    help='sigma candidates')
parser.add_argument('outfile', type=str, help='output file')

args = parser.parse_args()

def main():
    if not os.path.exists(os.path.dirname(args.outfile)):
        os.makedirs(os.path.dirname(args.outfile))

    sigma_list_str = '_'.join([f"%.3f" % sigma for sigma in args.sigma_list])
    plt.figure()
    legend = args.sigma_list.copy()
    sigma_certify_file = args.sigma_certify_file
    class_certify_file = args.class_certify_file

    sigma_radii = pd.read_csv(sigma_certify_file, sep='\t')
    class_radii = np.load(class_certify_file)

    sigma_choice = sigma_radii['predict'].values
    sigma_radii = sigma_radii['radius'].values
    sigma_radii = sigma_radii * (sigma_choice != -1)

    class_radii_real = class_radii[np.arange(class_radii.shape[0]), sigma_choice.astype(int) * (sigma_choice != -1)]

    final_radii = np.minimum(sigma_radii, class_radii_real)


    radius_step = 0.01
    radii = np.arange(0, 3.8 + radius_step, radius_step)

    for i in range(len(args.sigma_list)):
        radius = class_radii[:, i]
        accuracy_at_radius = []
        for r in radii:
            accuracy_at_radius.append(np.mean(radius >= r))
        plt.plot(radii, accuracy_at_radius, linestyle='--', linewidth=2) 

    accuracy_at_radius = []
    for r in radii:
        accuracy_at_radius.append(np.mean(sigma_radii >= r))
    plt.plot(radii, accuracy_at_radius)
    legend.append("Sigma radius")


    accuracy_at_radius = []
    for r in radii:
        accuracy_at_radius.append(np.mean(class_radii_real >= r))
    plt.plot(radii, accuracy_at_radius)
    legend.append("Class radius")

    accuracy_at_radius = []
    for r in radii:
        accuracy_at_radius.append(np.mean(final_radii >= r))
    plt.plot(radii, accuracy_at_radius, linewidth=2, color='black')
    legend.append("Final radius")

    plt.legend(legend, fontsize=18)
    plt.xlabel("Radius", fontsize=18)
    plt.ylabel("Accuracy", fontsize=18)
    plt.xticks(fontsize=18)
    plt.yticks(fontsize=18)
    plt.xlim([0, 3.8])
    plt.ylim([0, 1.0])
    plt.grid(which='both', axis='both')
    plt.savefig(args.outfile)

if __name__ == "__main__":
    main()
