解决Keras下训练CNN模型时,Loss值不断增大问题

2023-11-25 06:50

本文主要是介绍解决Keras下训练CNN模型时,Loss值不断增大问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景

在服务器上训练用keras写的Lenet5的CNN分类模型过程中,发现训练一开始训练的loss值、测试的loss值都在不断增大。如下图:(值大到吐血)
在这里插入图片描述
于是乎,开始心酸找bug历程(暴哭)

解决过程

1.通常先查看数据集。图像和标签是否对应。没问题(√)
2.模型结构问题,特别是最后输出时种类个数对不对。没问题(√)
3.权重初始化问题。训练之前模型自动初始化。没问题(√)
4.选择合适的激活函数(选的relu)、损失函数(交叉熵)、优化器(Adam)、学习率(初始0.0001,之后一定epoch后下降)。没问题(√)
5.我训练的数据是识别文本验证码,同时也检查了标签是否进行了one-hot编码。没问题(√)
6.老老实实看了遍全部代码。同样没问题(√)

在以上没问题的情况下,训练是loss值还是在不断增大。于是乎,我不知道该改什么了…就去找博士了…
首先博士看了遍代码。没有问题
在他电脑上(windows系统)运行,没有问题,loss值是在下降…
我愣住…同样的代码莫非我电脑自带bug???
最后发现是tensorflow版本问题!!
他的版本是1.19.0,我的是2.0.0
我…(一时语塞)

结论

1.如果遇到训练一开始loss值就增大问题,排除上面那几点外,看下运行的环境!!tensorflow的版本。
2.现在tensorflow版本没有1.19.0的了,我就安装了1.13.1的版本,python的版本是3.7.1。注意,在我windows上运行没有一点问题。
但当我将相同环境放到linux上运行时,就会报错:

ImportError:  /lib64/libm.so.6: version `GLIBC_2.23' not found

弄了半天安装glibc_2.23,结果最后只需要配了python==3.6版本的虚拟环境就正常了。原因可能是windows和linux所用到的C库可能不一样叭。

好了,总算是正常跑起来了的样子。(撒花)
在这里插入图片描述

后续

打扰了…训练的时候忘记安装gpu版本的tensorflow,就说怎么训练的这么慢…pip install tensorflow-gpu==version 安装对应版本的,我安装了1.8.0的。

这篇关于解决Keras下训练CNN模型时,Loss值不断增大问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/423306

相关文章

VSCode中C/C++编码乱码问题的两种解决方法

《VSCode中C/C++编码乱码问题的两种解决方法》在中国地区,Windows系统中的cmd和PowerShell默认编码是GBK,但VSCode默认使用UTF-8编码,这种编码不一致会导致在VSC... 目录问题方法一:通过 Code Runner 插件调整编码配置步骤方法二:在 PowerShell

mybatis-plus分页无效问题解决

《mybatis-plus分页无效问题解决》本文主要介绍了mybatis-plus分页无效问题解决,原因是配置分页插件的版本问题,旧版本和新版本的MyBatis-Plus需要不同的分页配置,感兴趣的可... 昨天在做一www.chinasem.cn个新项目使用myBATis-plus分页一直失败,后来经过多方

电脑开机提示krpt.dll丢失怎么解决? krpt.dll文件缺失的多种解决办法

《电脑开机提示krpt.dll丢失怎么解决?krpt.dll文件缺失的多种解决办法》krpt.dll是Windows操作系统中的一个动态链接库文件,它对于系统的正常运行起着重要的作用,本文将详细介绍... 在使用 Windows 操作系统的过程中,用户有时会遇到各种错误提示,其中“找不到 krpt.dll”

Linux虚拟机不显示IP地址的解决方法(亲测有效)

《Linux虚拟机不显示IP地址的解决方法(亲测有效)》本文主要介绍了通过VMware新装的Linux系统没有IP地址的解决方法,主要步骤包括:关闭虚拟机、打开VM虚拟网络编辑器、还原VMnet8或修... 目录前言步骤0.问题情况1.关闭虚拟机2.China编程打开VM虚拟网络编辑器3.1 方法一:点击还原VM

Flask解决指定端口无法生效问题

《Flask解决指定端口无法生效问题》文章讲述了在使用PyCharm开发Flask应用时,启动地址与手动指定的IP端口不一致的问题,通过修改PyCharm的运行配置,将Flask项目的运行模式从Fla... 目录android问题重现解决方案问题重现手动指定的IP端口是app.run(host='0.0.

Android WebView无法加载H5页面的常见问题和解决方法

《AndroidWebView无法加载H5页面的常见问题和解决方法》AndroidWebView是一种视图组件,使得Android应用能够显示网页内容,它基于Chromium,具备现代浏览器的许多功... 目录1. WebView 简介2. 常见问题3. 网络权限设置4. 启用 JavaScript5. D

Seata之分布式事务问题及解决方案

《Seata之分布式事务问题及解决方案》:本文主要介绍Seata之分布式事务问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Seata–分布式事务解决方案简介同类产品对比环境搭建1.微服务2.SQL3.seata-server4.微服务配置事务模式1

mysql关联查询速度慢的问题及解决

《mysql关联查询速度慢的问题及解决》:本文主要介绍mysql关联查询速度慢的问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql关联查询速度慢1. 记录原因1.1 在一次线上的服务中1.2 最终发现2. 解决方案3. 具体操作总结mysql

Python中Windows和macOS文件路径格式不一致的解决方法

《Python中Windows和macOS文件路径格式不一致的解决方法》在Python中,Windows和macOS的文件路径字符串格式不一致主要体现在路径分隔符上,这种差异可能导致跨平台代码在处理文... 目录方法 1:使用 os.path 模块方法 2:使用 pathlib 模块(推荐)方法 3:统一使

一文教你解决Python不支持中文路径的问题

《一文教你解决Python不支持中文路径的问题》Python是一种广泛使用的高级编程语言,然而在处理包含中文字符的文件路径时,Python有时会表现出一些不友好的行为,下面小编就来为大家介绍一下具体的... 目录问题背景解决方案1. 设置正确的文件编码2. 使用pathlib模块3. 转换路径为Unicod