0

0

TensorFlow模型训练:解决数据集划分导致NaN损失的问题

DDD

DDD

发布时间:2025-07-13 19:00:03

|

814人浏览过

|

来源于php中文网

原创

tensorflow模型训练:解决数据集划分导致nan损失的问题

摘要:本文旨在解决TensorFlow模型训练中,完整数据集训练导致损失变为NaN,而划分后的数据集训练正常的问题。核心原因是未对数据进行标准化,导致梯度爆炸。解决方案是在训练前使用StandardScaler对数据进行标准化,并强调先划分数据集再进行标准化的重要性,避免信息泄露。

在TensorFlow模型训练中,有时会遇到一种奇怪的现象:使用完整数据集进行训练时,损失函数迅速变为NaN(Not a Number),导致训练无法进行;而将数据集划分为训练集和测试集后,模型却能正常训练。 这种情况通常与数据的尺度和模型的激活函数有关。

问题分析:数据尺度与梯度爆炸

当模型使用ReLU等激活函数,并且输入数据的尺度较大时,容易出现梯度爆炸的问题。梯度爆炸会导致权重更新过大,从而使损失函数变为NaN。使用完整数据集训练时,由于每个epoch包含更多的数据,梯度更新的次数也更多,因此更容易触发梯度爆炸。

解决方案:数据标准化

解决梯度爆炸的有效方法之一是对数据进行标准化。标准化可以将数据的尺度缩放到一个较小的范围内,从而避免梯度爆炸的发生。常用的标准化方法包括:

造好物
造好物

一站式AI造物设计平台

下载
  • StandardScaler (Z-score标准化): 将数据转换为均值为0,标准差为1的分布。
from sklearn.preprocessing import StandardScaler
import numpy as np

# 示例数据
train_data = np.array([[1.0, 2.0], [1.5, 1.8], [1.2, 2.2]])
test_data = np.array([[2.0, 3.0], [2.5, 2.8]])

# 创建StandardScaler对象
scaler = StandardScaler()

# 在训练数据上拟合scaler
scaler.fit(train_data)

# 使用scaler转换训练数据和测试数据
train_data_scaled = scaler.transform(train_data)
test_data_scaled = scaler.transform(test_data)

print("原始训练数据:\n", train_data)
print("标准化后的训练数据:\n", train_data_scaled)
print("原始测试数据:\n", test_data)
print("标准化后的测试数据:\n", test_data_scaled)

重要提示:先划分数据集,再进行标准化

务必在划分数据集之后再进行标准化。如果在划分数据集之前进行标准化,会将测试集的信息泄露到训练集中,导致模型评估结果不准确。

正确的流程应该是:

  1. 将数据集划分为训练集和测试集。
  2. 训练集上拟合StandardScaler。
  3. 使用拟合的StandardScaler分别转换训练集和测试集。
from sklearn.model_selection import train_test_split
from sklearn.preprocessing import StandardScaler
import numpy as np

# 示例数据
data = np.array([[1.0, 2.0], [1.5, 1.8], [1.2, 2.2], [2.0, 3.0], [2.5, 2.8]])
labels = np.array([0, 0, 0, 1, 1])

# 划分数据集
X_train, X_test, y_train, y_test = train_test_split(data, labels, test_size=0.2, random_state=42)

# 创建StandardScaler对象
scaler = StandardScaler()

# 在训练数据上拟合scaler
scaler.fit(X_train)

# 使用scaler转换训练数据和测试数据
X_train_scaled = scaler.transform(X_train)
X_test_scaled = scaler.transform(X_test)

print("训练集:\n", X_train)
print("测试集:\n", X_test)
print("标准化后的训练集:\n", X_train_scaled)
print("标准化后的测试集:\n", X_test_scaled)

总结

当TensorFlow模型在完整数据集上训练时出现NaN损失,而在划分后的数据集上训练正常时,很可能是由于数据尺度过大导致梯度爆炸。通过使用StandardScaler等方法对数据进行标准化,可以有效解决这个问题。 切记,在进行标准化之前,必须先将数据集划分为训练集和测试集,以避免信息泄露。 此外,选择合适的学习率和激活函数也有助于稳定模型的训练过程。

相关专题

更多
Python AI机器学习PyTorch教程_Python怎么用PyTorch和TensorFlow做机器学习
Python AI机器学习PyTorch教程_Python怎么用PyTorch和TensorFlow做机器学习

PyTorch 是一种用于构建深度学习模型的功能完备框架,是一种通常用于图像识别和语言处理等应用程序的机器学习。 使用Python 编写,因此对于大多数机器学习开发者而言,学习和使用起来相对简单。 PyTorch 的独特之处在于,它完全支持GPU,并且使用反向模式自动微分技术,因此可以动态修改计算图形。

19

2025.12.22

Python 深度学习框架与TensorFlow入门
Python 深度学习框架与TensorFlow入门

本专题深入讲解 Python 在深度学习与人工智能领域的应用,包括使用 TensorFlow 搭建神经网络模型、卷积神经网络(CNN)、循环神经网络(RNN)、数据预处理、模型优化与训练技巧。通过实战项目(如图像识别与文本生成),帮助学习者掌握 如何使用 TensorFlow 开发高效的深度学习模型,并将其应用于实际的 AI 问题中。

17

2026.01.07

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

34

2026.01.14

php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

14

2026.01.13

PHP 高性能
PHP 高性能

本专题整合了PHP高性能相关教程大全,阅读专题下面的文章了解更多详细内容。

33

2026.01.13

MySQL数据库报错常见问题及解决方法大全
MySQL数据库报错常见问题及解决方法大全

本专题整合了MySQL数据库报错常见问题及解决方法,阅读专题下面的文章了解更多详细内容。

18

2026.01.13

PHP 文件上传
PHP 文件上传

本专题整合了PHP实现文件上传相关教程,阅读专题下面的文章了解更多详细内容。

12

2026.01.13

PHP缓存策略教程大全
PHP缓存策略教程大全

本专题整合了PHP缓存相关教程,阅读专题下面的文章了解更多详细内容。

6

2026.01.13

jQuery 正则表达式相关教程
jQuery 正则表达式相关教程

本专题整合了jQuery正则表达式相关教程大全,阅读专题下面的文章了解更多详细内容。

3

2026.01.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号