我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Python绘制loss曲线、准确率曲线

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Python绘制loss曲线、准确率曲线

Python 绘制 loss 曲线、准确率曲线

使用 python 绘制网络训练过程中的的 loss 曲线以及准确率变化曲线,这里的主要思想就时先把想要的损失值以及准确率值保存下来,保存到 .txt 文件中,待网络训练结束,我们再拿这存储的数据绘制各种曲线。

其大致步骤为:数据读取与存储 - > loss曲线绘制 - > 准确率曲线绘制

一、数据读取与存储部分

我们首先要得到训练时的数据,以损失值为例,网络每迭代一次都会产生相应的 loss,那么我们就把每一次的损失值都存储下来,存储到列表,保存到 .txt 文件中。保存的文件如下图所示:

[1.3817585706710815, 1.8422836065292358, 1.1619832515716553, 0.5217241644859314, 0.5221078991889954, 1.3544578552246094, 1.3334463834762573, 1.3866571187973022, 0.7603049278259277]

上图为部分损失值,根据迭代次数而异,要是迭代了1万次,这里就会有1万个损失值。
而准确率值是每一个 epoch 产生一个值,要是训练100个epoch,就有100个准确率值。

(那么问题来了,这里的损失值是怎么保存到文件中的呢? 很少有人讲这个,也有一些小伙伴们来咨询,这里就统一记录一下,包括损失值和准确率值。)

首先,找到网络训练代码,就是项目中的 main.py,或者 train.py ,在文件里先找到训练部分,里面经常会有这样一行代码:

for epoch in range(resume_epoch, num_epochs):   # 就是这一行####...loss = criterion(outputs, labels.long())              # 损失样例...    epoch_acc = running_corrects.double() / trainval_sizes[phase]    # 准确率样例    ...    ###

从这一行开始就是训练部分了,往下会找到类似的这两句代码,就是损失值和准确率值了。

这时候将以下代码加入源代码就可以了:

train_loss = []train_acc = []for epoch in range(resume_epoch, num_epochs):          # 就是这一行###...loss = criterion(outputs, labels.long())           # 损失样例train_loss.append(loss.item())                     # 损失加入到列表中...epoch_acc = running_corrects.double() / trainval_sizes[phase]    # 准确率样例train_acc.append(epoch_acc.item())                 # 准确率加入到列表中... with open("./train_loss.txt", 'w') as train_los:    train_los.write(str(train_loss))with open("./train_acc.txt", 'w') as train_ac:     train_ac.write(str(train_acc))

这样就算完成了损失值和准确率值的数据存储了!

二、绘制 loss 曲线

主要需要 numpy 库和 matplotlib 库,如果不会安装可以自行百度,很简单。

首先,将 .txt 文件中的存储的数据读取进来,以下是读取函数:

import numpy as np# 读取存储为txt文件的数据def data_read(dir_path):    with open(dir_path, "r") as f:        raw_data = f.read()        data = raw_data[1:-1].split(", ")   # [-1:1]是为了去除文件中的前后中括号"[]"    return np.asfarray(data, float)

然后,就是绘制 loss 曲线部分:

if __name__ == "__main__":train_loss_path = r"E:\relate_code\Gaitpart-master\train_loss.txt"   # 存储文件路径y_train_loss = data_read(train_loss_path)        # loss值,即y轴x_train_loss = range(len(y_train_loss)) # loss的数量,即x轴plt.figure()    # 去除顶部和右边框框    ax = plt.axes()    ax.spines['top'].set_visible(False)    ax.spines['right'].set_visible(False)    plt.xlabel('iters')    # x轴标签    plt.ylabel('loss')     # y轴标签# 以x_train_loss为横坐标,y_train_loss为纵坐标,曲线宽度为1,实线,增加标签,训练损失,# 默认颜色,如果想更改颜色,可以增加参数color='red',这是红色。    plt.plot(x_train_loss, y_train_loss, linewidth=1, linestyle="solid", label="train loss")    plt.legend()    plt.title('Loss curve')    plt.show()

这样就算把损失图像画出来了!如下:
在这里插入图片描述

三、绘制准确率曲线

有了上面的基础,这就简单很多了。
只是有一点要记住,上面的x轴是迭代次数,这里的是训练轮次 epoch。

if __name__ == "__main__":train_acc_path = r"E:\relate_code\Gaitpart-master\train_acc.txt"   # 存储文件路径y_train_acc = data_read(train_acc_path)       # 训练准确率值,即y轴x_train_acc = range(len(y_train_acc)) # 训练阶段准确率的数量,即x轴plt.figure()    # 去除顶部和右边框框    ax = plt.axes()    ax.spines['top'].set_visible(False)    ax.spines['right'].set_visible(False)    plt.xlabel('epochs')    # x轴标签    plt.ylabel('accuracy')     # y轴标签# 以x_train_acc为横坐标,y_train_acc为纵坐标,曲线宽度为1,实线,增加标签,训练损失,# 增加参数color='red',这是红色。    plt.plot(x_train_acc, y_train_acc, color='red',linewidth=1, linestyle="solid", label="train acc")    plt.legend()    plt.title('Accuracy curve')    plt.show()

这样就把准确率变化曲线画出来了!如下:
在这里插入图片描述
以下是完整代码,以绘制准确率曲线为例,并且将x轴换成了iters,和损失曲线保持一致,供参考:

import numpy as npimport matplotlib.pyplot as plt# 读取存储为txt文件的数据def data_read(dir_path):    with open(dir_path, "r") as f:        raw_data = f.read()        data = raw_data[1:-1].split(", ")    return np.asfarray(data, float)# 不同长度数据,统一为一个标准,倍乘x轴def multiple_equal(x, y):    x_len = len(x)    y_len = len(y)    times = x_len/y_len    y_times = [i * times for i in y]    return y_timesif __name__ == "__main__":    train_loss_path = r"E:\relate_code\Gaitpart-master\file_txt\train_loss.txt"    train_acc_path = r"E:\relate_code\Gaitpart-master\train_acc.txt"    y_train_loss = data_read(train_loss_path)    y_train_acc = data_read(train_acc_path)    x_train_loss = range(len(y_train_loss))    x_train_acc = multiple_equal(x_train_loss, range(len(y_train_acc)))    plt.figure()    # 去除顶部和右边框框    ax = plt.axes()    ax.spines['top'].set_visible(False)    ax.spines['right'].set_visible(False)    plt.xlabel('iters')    plt.ylabel('accuracy')    # plt.plot(x_train_loss, y_train_loss, linewidth=1, linestyle="solid", label="train loss")    plt.plot(x_train_acc, y_train_acc,  color='red', linestyle="solid", label="train accuracy")    plt.legend()    plt.title('Accuracy curve')    plt.show()

日常学习记录,一起交流讨论吧!侵权联系~

来源地址:https://blog.csdn.net/WYKB_Mr_Q/article/details/125661871

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Python绘制loss曲线、准确率曲线

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

用Python绘制正弦曲线

今天学了Python 绘制了一幅正弦曲线 哈哈需要numpy  Python 库的支持>>>import numpy as np >>> import matplotlib.pyplot as plt >>> x=np.arange(-np
2023-01-31

Python中ROC曲线怎么绘制

本篇内容介绍了“Python中ROC曲线怎么绘制”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!首先以支持向量机模型为例先导入需要使用的包,我
2023-06-22

Python中怎么绘制各种曲线

本篇文章为大家展示了 Python中怎么绘制各种曲线,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Python 代码如下:import numpy as np import matplotlib.
2023-06-15

怎么利用Python绘制科赫曲线

本篇内容主要讲解“怎么利用Python绘制科赫曲线”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么利用Python绘制科赫曲线”吧!1. 递归1.1 定义函数作为一种代码封装, 可以被其他程序
2023-06-30

C#怎么绘制实时曲线

这篇文章主要讲解了“C#怎么绘制实时曲线”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C#怎么绘制实时曲线”吧!1.要做一个调试工具,采集传感器数据并显示。绘制曲线注意坐标反转,线条的张力即
2023-06-29

PyQt5+QtChart实现绘制曲线图

QChart是一个QGraphicScene中可以显示的QGraphicsWidget。本文将利用QtChart实现曲线图的绘制,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下
2022-12-15

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录