import sklearn.metrics as skm
import numpy as np

def low_density_anomalies(test_log_probs, num_anomalies):
    """ Helper function for the F1-score, selects the num_anomalies lowest values of test_log_prob
    """
    print(test_log_probs.shape)
    print(num_anomalies)
    
    anomaly_indices = np.argpartition(test_log_probs, num_anomalies-1)[:num_anomalies]
    preds = np.zeros(len(test_log_probs))
    preds[anomaly_indices] = 1
    return preds


def calculate_metrics_threshold(config, all_mse, labels):
        mse_np = np.squeeze(np.array(all_mse))
        mask = labels == 0
        mse_no_anom_np = mse_np[mask]

        mean = np.mean(mse_no_anom_np)
        std = np.std(mse_no_anom_np)
        trashhold_value = mean + 2*std
        print("Mean: ", mean, " Std: ", std)

        preds = mse_np > trashhold_value
        preds = preds.astype(int)

        indices = np.arange(len(labels))
        p = low_density_anomalies(-mse_np, len(indices[labels==1]))


        f1_score_opt = skm.f1_score(labels, p)
        aucroc_direct = skm.roc_auc_score(y_true=labels, y_score=mse_np)
        aucpr = skm.average_precision_score(y_true=labels, y_score=mse_np, pos_label=1)

        print("Aucpr", aucpr)
        print("Auroc", aucroc_direct)

        import time

        # print("Warte 3 Sekunden...")
        # time.sleep(3)

        return  f1_score_opt, aucroc_direct, aucpr


