解读Tensorflow2.0训练损失值降低,但测试正确率基本不变的情况

 更新时间:2023年06月25日 10:08:06   作者:mu_xing_  
这篇文章主要介绍了Tensorflow2.0训练损失值降低,但测试正确率基本不变的情况,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

Tensorflow2.0训练损失值降低,但测试正确率基本不变的情况

问题描述

对于一个架构,在识别mnist手写数字集精度较高的情况下,更换其他数据集,却无法得到较高的识别结果。假设有n个类别,修改输入端、输出端及几个卷积核的大小,识别时虽然loss在减小,但正确率acc稳定在1/n左右不变化。

解决方法

修改参数

主要考虑的参数有batch、学习率和keep_prob:

  • batch ,降低该值,使得网络充分学习数据;
  • 学习率,降低该值,使得模型梯度下降;
  • keep_prob ,降低该值,使得模型具有学习能力。

检查模型

检查模型是否有问题,修改网络的架构。

loss计算方法

选择loss计算的公式方法是否有问题。

数据标签

检查数据的标签是否转换正确。

权重初始值

修改权重的初始化方法。

Tensorflow2.0准确率和损失值的可视化

进行准确率和损失值的可视化,就是将acc和loss使用matplot画出来。

我们在使用model.fit()函数进行训练时,同步记录了训练集和测试集的损失和准确率。

可以使用history进行调用,如下:

#  使用history将训练集和测试集的loss和acc调出来
acc = history.history['sparse_categorical_accuracy']  # 训练集准确率
val_acc = history.history['val_sparse_categorical_accuracy']  # 测试集准确率
loss = history.history['loss']  # 训练集损失
val_loss = history.history['val_loss']  # 测试集损失
#  打印acc和loss,采用一个图进行显示。
#  将acc打印出来。
plt.subplot(1, 2, 1)  # 将图像分为一行两列,将其显示在第一列
plt.plot(acc, label='Training Accuracy')
plt.plot(val_acc, label='Validation Accuracy')
plt.title('Training and Validation Accuracy')
plt.legend()
plt.subplot(1, 2, 2)  # 将其显示在第二列
plt.plot(loss, label='Training Loss')
plt.plot(val_loss, label='Validation Loss')
plt.title('Training and Validation Loss')
plt.legend()
plt.show()

将本篇代码放在上篇文章代码后,运行即可。

输出结果:

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Python自动化测试Eclipse+Pydev 搭建开发环境

    Python自动化测试Eclipse+Pydev 搭建开发环境

    本文主要介绍python自动化测试环境搭建,这里对Eclipse+Pydev 搭建开发环境做了图文详解,有需要的小伙伴可以参考下
    2016-08-08
  • Python中pycharm编辑器界面风格修改方法

    Python中pycharm编辑器界面风格修改方法

    这篇文章主要介绍了Python中pycharm编辑器界面风格修改方法,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-03-03
  • wxPython的安装与使用教程

    wxPython的安装与使用教程

    wxPython是Python语言的一套优秀的GUI图形库。wxPython可以很方便的创建完整的、功能键全的GUI用户界面。这篇文章给大家介绍了wxPython的安装与使用,感兴趣的朋友一起看看吧
    2018-08-08
  • Python实现模拟锟斤拷等各类乱码详解

    Python实现模拟锟斤拷等各类乱码详解

    说到乱码问题就不得不提到锟斤拷,这算是非常常见的一种乱码形式,那么它到底是经过何种错误操作产生的呢?本文我们就来一步步探究
    2023-02-02
  • Python协程异步爬取数据(asyncio+aiohttp)实例

    Python协程异步爬取数据(asyncio+aiohttp)实例

    这篇文章主要为大家介绍了Python协程异步爬取数据(asyncio+aiohttp)实现示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-08-08
  • python实现比较两段文本不同之处的方法

    python实现比较两段文本不同之处的方法

    这篇文章主要介绍了python实现比较两段文本不同之处的方法,涉及Python针对文本与字符串的相关操作技巧,需要的朋友可以参考下
    2015-05-05
  • 利用Python编写的实用运维脚本分享

    利用Python编写的实用运维脚本分享

    Python在很大程度上可以对shell脚本进行替代。笔者一般单行命令用shell,复杂点的多行操作就直接用Python了。本文归纳了Python中一些实用脚本操作,需要的可以参考一下
    2022-05-05
  • Django框架安装及项目创建过程解析

    Django框架安装及项目创建过程解析

    这篇文章主要介绍了Django框架安装及项目创建过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09
  • Python如何将控制台输出另存为日志文件

    Python如何将控制台输出另存为日志文件

    这篇文章主要介绍了Python如何将控制台输出另存为日志文件问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-05-05
  • python操作excel的方法(xlsxwriter包的使用)

    python操作excel的方法(xlsxwriter包的使用)

    这篇文章主要为大家详细介绍了python操作excel的方法,xlsxwriter包的使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-06-06

最新评论