matplotlib画混淆矩阵与正确率曲线的实例代码


Posted in Python onJune 01, 2021

混淆矩阵    

混淆矩阵(Confusion Matrix)是机器学习中用来总结分类模型预测结果的一个分析表,是模式识别领域中的一种常用的表达形式。它以矩阵的形式描绘样本数据的真实属性和分类预测结果类型之间的关系,是用来评价分类器性能的一种常用方法。

我们可以通过一个简单的例子来直观理解混淆矩阵

#!/usr/bin/python3.5
# -*- coding: utf-8 -*-
import numpy as np
import matplotlib.pyplot as plt
plt.rcParams['font.sans-serif'] = ['FangSong']  #可显示中文字符
plt.rcParams['axes.unicode_minus']=False
classes = ['a','b','c','d','e','f','g']
confusion_matrix = np.array([(99,1,2,2,0,0,6),(1,98,7,6,2,1,1),(0,0,86,0,0,2,0),(0,0,0,86,1,0,0),(0,0,0,1,94,1,0),(0,1,5,1,0,96,8),(0,0,0,4,3,0,85)],dtype=np.float64)
 
plt.imshow(confusion_matrix, interpolation='nearest', cmap=plt.cm.Oranges)  #按照像素显示出矩阵
plt.title('混淆矩阵')
plt.colorbar()
tick_marks = np.arange(len(classes))
plt.xticks(tick_marks, classes, rotation=-45)
plt.yticks(tick_marks, classes)
 
thresh = confusion_matrix.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(7)] for i in range(7)],(confusion_matrix.size,2))
for i, j in iters:
    plt.text(j, i, format(confusion_matrix[i, j]),fontsize=7)   #显示对应的数字
 
plt.ylabel('真实类别')
plt.xlabel('预测类别')
plt.tight_layout()
plt.show()

正确率曲线 

fig ,ax= plt.subplots()
    plt.plot(np.arange(iterations), fig_acc,'b')
    plt.plot(np.arange(iterations), fig_realacc, 'r')
    ax.set_xlabel('迭代次数')
    ax.set_ylabel('正确率(%)')
 
    labels = ["训练正确率", "测试正确率"]
    # labels = [l.get_label() for l in lns]
    plt.legend( labels, loc=7)
    plt.show()

总结

到此这篇关于matplotlib画混淆矩阵与正确率曲线的文章就介绍到这了,更多相关matplotlib画混淆矩阵内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
python使用urllib模块开发的多线程豆瓣小站mp3下载器
Jan 16 Python
跟老齐学Python之重回函数
Oct 10 Python
深入解析Python中的urllib2模块
Nov 13 Python
python用reduce和map把字符串转为数字的方法
Dec 19 Python
简单的python协同过滤程序实例代码
Jan 31 Python
numpy.random.seed()的使用实例解析
Feb 03 Python
Python中 传递值 和 传递引用 的区别解析
Feb 22 Python
对Python 网络设备巡检脚本的实例讲解
Apr 22 Python
python list是否包含另一个list所有元素的实例
May 04 Python
树莓派+摄像头实现对移动物体的检测
Jun 22 Python
Python中请不要再用re.compile了
Jun 30 Python
python selenium循环登陆网站的实现
Nov 04 Python
详细介绍python类及类的用法
教你怎么用PyCharm为同一服务器配置多个python解释器
用python批量解压带密码的压缩包
May 31 #Python
变长双向rnn的正确使用姿势教学
如何在Python项目中引入日志
Tensorflow与RNN、双向LSTM等的踩坑记录及解决
Python数据类型最全知识总结
May 31 #Python
You might like
用Apache反向代理设置对外的WWW和文件服务器
2006/10/09 PHP
深入php var_dump()函数的详解
2013/06/05 PHP
php中3种方法删除字符串中间的空格
2014/03/10 PHP
Yii实现自动加载类地图的方法
2015/04/01 PHP
PHP7.0版本备注
2015/07/23 PHP
PHP计算数组中值的和与乘积的方法(array_sum与array_product函数)
2016/04/01 PHP
jQuery ajax+PHP实现的级联下拉列表框功能示例
2019/02/12 PHP
jQuery 学习6 操纵元素显示效果的函数
2010/02/07 Javascript
Cookie 小记
2010/04/01 Javascript
IE6-8中Date不支持toISOString的修复方法
2014/05/04 Javascript
JavaScript实现Java中Map容器的方法
2016/10/09 Javascript
自定义vue组件发布到npm的方法
2018/05/09 Javascript
JavaScript中为事件指定处理程序的五种方式分析
2018/07/27 Javascript
jQuery中DOM常见操作实例小结
2019/08/01 jQuery
package.json配置文件构成详解
2019/08/27 Javascript
解决Vue 刷新页面导航显示高亮位置不对问题
2019/12/25 Javascript
Vue循环中多个input绑定指定v-model实例
2020/08/31 Javascript
django 发送手机验证码的示例代码
2018/04/25 Python
python+selenium实现自动抢票功能实例代码
2018/11/23 Python
python命令行参数用法实例分析
2019/06/25 Python
详解Anconda环境下载python包的教程(图形界面+命令行+pycharm安装)
2019/11/11 Python
python eventlet绿化和patch原理
2020/11/21 Python
Python 实现一个简单的web服务器
2021/01/03 Python
用CSS3实现背景渐变的方法
2015/07/14 HTML / CSS
通用C#笔试题附答案
2016/11/26 面试题
单位人事专员介绍信
2014/01/11 职场文书
正科级干部考察材料
2014/05/29 职场文书
党的群众路线教育实践活动通讯稿
2014/09/10 职场文书
写给妈妈的感谢信
2015/01/22 职场文书
五四青年节比赛演讲稿
2015/03/18 职场文书
刑事法律意见书
2015/06/04 职场文书
师德师风培训感言
2015/08/03 职场文书
蓝天保卫战收官在即 :15行业将开展环保分级评价
2019/07/19 职场文书
如何利用python和DOS获取wifi密码
2021/03/31 Python
mongodb数据库迁移变更的解决方案
2021/09/04 MongoDB
Windows server 2012 配置Telnet以及用法详解
2022/04/28 Servers