机器学习之混淆矩阵的两种画法(实战)

混淆矩阵主要用于表示分类精度,利用横轴为预测结果,纵轴为标准结果的表格图,可视化地展示算法的分类性能。

import seaborn as sns
sns.set()
C2 = confusion_matrix(y_test, y_predict, labels=[0,1,2])


# # 方法一
# f, ax = plt.subplots()
# print(C2)  # 打印出来看看
# sns.heatmap(C2, annot=True, ax=ax)  # 画热力图
#
# ax.set_title('混淆矩阵')  # 标题
# ax.set_xlabel('predict')  # x轴
# ax.set_ylabel('true')  # y轴
# plt.show()

方法二:

plt.figure()
classes = [0,1,2]
plt.imshow(C2, interpolation='nearest', cmap=plt.cm.Oranges)  # 按照像素显示出矩阵
plt.title('confusion_matrix')
plt.colorbar()
tick_marks = np.arange(len(classes))
plt.xticks(tick_marks, classes)
plt.yticks(tick_marks, classes)

thresh = C2.max() / 2.
# iters = [[i,j] for i in range(len(classes)) for j in range((classes))]
# ij配对,遍历矩阵迭代器
iters = np.reshape([[[i, j] for j in range(len(classes))] for i in range(len(classes))], (C2.size, 2))
for i, j in iters:
    plt.text(j, i, format(C2[i, j]))  # 显示对应的数字

plt.ylabel('Real label')
plt.xlabel('Prediction')
plt.tight_layout()
plt.show()

 

三分类的混淆矩阵

可以看出,因为数据量的严重不均衡,但是,模型的识别能力还是蛮不错的;

  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值