File size: 1,434 Bytes
8360ec7 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 |
# code for general evaluation
import numpy as np
import evaluate
from sklearn.metrics import precision_recall_fscore_support, accuracy_score
def evaluate_classification(preds, gold):
metric = evaluate.load("bstrai/classification_report")
return metric.compute(predictions=preds, references=gold)
def eval_classification(y_true, y_pred, average="macro"):
precision, recall, F1, support = precision_recall_fscore_support(y_true, y_pred, average=average)
accuracy = accuracy_score(y_true, y_pred)
metrics = {
"accuracy": round(accuracy, 3),
"precision": round(precision, 3),
"recall": round(recall, 3),
"F1": round(F1, 3),
}
return metrics
def eval_binary(y_true, y_pred, pos_label=1, average="binary"):
"""pos_label: postive label is machine text here, label is 1, human text is 0"""
precision, recall, F1, support = precision_recall_fscore_support(
y_true, y_pred, pos_label = pos_label, average = average)
# accuracy
accuracy = accuracy_score(y_true, y_pred)
# precison
# pre = precision_score(y_true, y_pred, pos_label = pos_label, average = average)
# recall
# rec = recall_score(y_true, y_pred, pos_label = pos_label, average = average)
metrics = {
"accuracy": round(accuracy, 3),
"precision": round(precision, 3),
"recall": round(recall, 3),
"F1": round(F1, 3),
}
return metrics
|