from: https://zhuanlan.zhihu.com/p/368196647
多分类
from sklearn.metrics import classification_report
y_true = [0, 1, 2, 2, 2]
y_pred = [0, 0, 2, 2, 1]
target_names = ['class 0', 'class 1', 'class 2']
print(classification_report(y_true, y_pred))
data:image/s3,"s3://crabby-images/cbf20/cbf204976daac39a6ba7f1d3fea9576f23844740" alt="在这里插入图片描述"
多标签分类
import numpy as np
from sklearn.metrics import classification_report
y_true = np.array([ [1, 0, 1, 0, 0],
[0, 1, 0, 1, 1],
[1, 1, 1, 0, 1]])
y_pred = np.array([[1, 0, 0, 0, 1],
[0, 1, 1, 1, 0],
[1, 1, 1, 0, 0]])
print(classification_report(y_true, y_pred, digits=3))
理解多标签分类中 micro avg, precision表示所有预测1中,对的个数,所以是/8;recall表示所有样本1中,对的个数,所以是/9
data:image/s3,"s3://crabby-images/bee0c/bee0cd003114ca9b367e62f0cc3a72083a31e9ca" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/d89ca/d89ca610b7c016fdcd4776a6a2e7cf02c1e70855" alt="在这里插入图片描述"