from sklearn.metrics import roc_auc_score, accuracy_score, precision_recall_curve, auc
import numpy as np

def auroc_score(y_true, y_scores):
    y_true = np.array(y_true)
    y_scores = np.array(y_scores)
    score = roc_auc_score(y_true, y_scores)
    return score

def acc_score(y_true, y_pred, is_label=False, threshold=None):
    y_true = np.array(y_true)
    y_pred = np.array(y_pred)
    if not is_label:
        acc_list = []
        if threshold is None:
            thresholds = np.sort(y_pred)
        else:
            thresholds = [threshold]
        
        for t in thresholds:
            acc = accuracy_score(y_true, (y_pred >= t).astype(int))
            acc_list.append(acc)
        acc_score = np.max(np.array(acc_list))
        threshold = thresholds[np.argmax(np.array(acc_list))]
    else:
        acc_score = accuracy_score(y_true, y_pred)
        threshold = None
    
    return acc_score, threshold

def p_r_f1(y_true, y_pred):
    precision, recall, thresholds = precision_recall_curve(y_true, y_pred)
    auc_pr = auc(recall, precision)
    f1_list = []
    for p, r in zip(precision, recall):
        if (p + r) == 0:
            f1_list.append(0)
            print("divide zero error!")
            continue
        f1 = (2 * p * r) / (p + r)
        f1_list.append(f1)
    f1 = max(f1_list)
    p, r = list(zip(precision, recall))[np.argmax(np.array(f1_list))]

    
    
    return {"precision": p, "recall": r, "f1": f1, "aucpr": auc_pr}
# y_true = [1, 0, 0, 0, 1, 0, 1, 0]  # 真实标签
# y_scores = [91, 0.8, 0.3, 0.1, 0.4, 91, 0.66, 0.7] # 模型预测为正类的概率
# auroc_score = auroc_score(y_true, y_scores)

# print("AUROC score:", auroc_score)

# y_true = [0, 0, 1, 1]  # 真实标签
# y_scores = [0.1, 0.4, 0.35, 0.8] # 模型预测为正类的概率
# acc_score = max_f1(y_true, y_scores)

# print("f1 score:", acc_score)
