python机器学习 二分类 混淆矩阵_机器学习之混淆矩阵的两种画法(实战)

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

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()

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值