【Python机器学习】实现二分类混淆矩阵可视化

  直接上代码

def cm_plot(y, yp):
    '''
    y: 真实值
    y_pred:预测值
    '''
    '''混淆矩阵绘画'''
    from sklearn.metrics import confusion_matrix  # 导入混淆矩阵函数

    cm = confusion_matrix(y, yp)  # 混淆矩阵
    print('混淆矩阵为:\n',cm)
    import matplotlib.pyplot as plt  # 导入作图库
    plt.matshow(cm, cmap=plt.cm.Greens)  # 画混淆矩阵图,配色风格使用cm.Greens,更多风格请参考官网。
    plt.colorbar()  # 颜色标签

    for x in range(len(cm)):  # 数据标签
        for y in range(len(cm)):
            plt.annotate(cm[x, y], xy=(y, x),verticalalignment='center',horizontalalignment='center')
            # 这边一个重要的易错点就是关于xy需要添加数值的位置的点要换成(y, x),因为矩阵可视化的xy与实际意义上的坐标是相反的
    plt.ylabel('True label')  # 坐标轴标签
    plt.xlabel('Predicted label')  # 坐标轴标签
    plt.show()

  • 4
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
LightGBM是一种基于梯度提升决策树(Gradient Boosting Decision Tree)的机器学习算法。混淆矩阵可视化是评估分类模型性能的一种常用方法,可以直观地展示模型在不同类别上的预测结果。 要进行混淆矩阵可视化,首先需要使用LightGBM模型对测试数据进行预测,并得到预测结果。然后,根据预测结果和真实标签,计算混淆矩阵混淆矩阵是一个二维矩阵,行表示真实标签,列表示预测结果,每个元素表示对应类别的样本数量。 接下来,可以使用各种数据可视化工具(如Matplotlib、Seaborn等)将混淆矩阵可视化。一种常见的可视化方式是使用热力图(heatmap),将混淆矩阵的数值以颜色的形式展示出来。颜色的深浅表示对应类别的样本数量多少,可以直观地观察到模型在不同类别上的预测准确性。 以下是使用Python和Matplotlib库进行混淆矩阵可视化的示例代码: ```python import numpy as np import matplotlib.pyplot as plt import seaborn as sns # 模拟混淆矩阵数据 confusion_matrix = np.array([[100, 20, 30], [10, 150, 20], [5, 10, 120]]) # 设置标签 labels = ['Class 0', 'Class 1', 'Class 2'] # 绘制热力图 plt.figure(figsize=(8, 6)) sns.heatmap(confusion_matrix, annot=True, fmt='d', cmap='Blues', xticklabels=labels, yticklabels=labels) plt.xlabel('Predicted label') plt.ylabel('True label') plt.title('Confusion Matrix') plt.show() ``` 这段代码会生成一个热力图,横轴表示预测结果,纵轴表示真实标签,每个格子中的数字表示对应类别的样本数量。颜色越深表示数量越多,可以直观地观察到模型在不同类别上的预测情况。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值