【问题标题】:Interpreting training trace of a deep neural network: very low training loss and even lower validation loss解释深度神经网络的训练轨迹:非常低的训练损失,甚至更低的验证损失
【发布时间】:2017-06-14 01:03:10
【问题描述】:

我对以下日志有点怀疑,这是我在为 -1.0 和 1.0 之间的回归目标值训练深度神经网络时得到的,学习率为 0.001 和 19200/4800 个训练/验证样本:

____________________________________________________________________________________________________
Layer (type)                     Output Shape          Param #     Connected to
====================================================================================================
cropping2d_1 (Cropping2D)        (None, 138, 320, 3)   0           cropping2d_input_1[0][0]
____________________________________________________________________________________________________
lambda_1 (Lambda)                (None, 66, 200, 3)    0           cropping2d_1[0][0]
____________________________________________________________________________________________________
lambda_2 (Lambda)                (None, 66, 200, 3)    0           lambda_1[0][0]
____________________________________________________________________________________________________
convolution2d_1 (Convolution2D)  (None, 31, 98, 24)    1824        lambda_2[0][0]
____________________________________________________________________________________________________
spatialdropout2d_1 (SpatialDropo (None, 31, 98, 24)    0           convolution2d_1[0][0]
____________________________________________________________________________________________________
convolution2d_2 (Convolution2D)  (None, 14, 47, 36)    21636       spatialdropout2d_1[0][0]
____________________________________________________________________________________________________
spatialdropout2d_2 (SpatialDropo (None, 14, 47, 36)    0           convolution2d_2[0][0]
____________________________________________________________________________________________________
convolution2d_3 (Convolution2D)  (None, 5, 22, 48)     43248       spatialdropout2d_2[0][0]
____________________________________________________________________________________________________
spatialdropout2d_3 (SpatialDropo (None, 5, 22, 48)     0           convolution2d_3[0][0]
____________________________________________________________________________________________________
convolution2d_4 (Convolution2D)  (None, 3, 20, 64)     27712       spatialdropout2d_3[0][0]
____________________________________________________________________________________________________
spatialdropout2d_4 (SpatialDropo (None, 3, 20, 64)     0           convolution2d_4[0][0]
____________________________________________________________________________________________________
convolution2d_5 (Convolution2D)  (None, 1, 18, 64)     36928       spatialdropout2d_4[0][0]
____________________________________________________________________________________________________
spatialdropout2d_5 (SpatialDropo (None, 1, 18, 64)     0           convolution2d_5[0][0]
____________________________________________________________________________________________________
flatten_1 (Flatten)              (None, 1152)          0           spatialdropout2d_5[0][0]
____________________________________________________________________________________________________
dropout_1 (Dropout)              (None, 1152)          0           flatten_1[0][0]
____________________________________________________________________________________________________
activation_1 (Activation)        (None, 1152)          0           dropout_1[0][0]
____________________________________________________________________________________________________
dense_1 (Dense)                  (None, 100)           115300      activation_1[0][0]
____________________________________________________________________________________________________
dropout_2 (Dropout)              (None, 100)           0           dense_1[0][0]
____________________________________________________________________________________________________
dense_2 (Dense)                  (None, 50)            5050        dropout_2[0][0]
____________________________________________________________________________________________________
dense_3 (Dense)                  (None, 10)            510         dense_2[0][0]
____________________________________________________________________________________________________
dropout_3 (Dropout)              (None, 10)            0           dense_3[0][0]
____________________________________________________________________________________________________
dense_4 (Dense)                  (None, 1)             11          dropout_3[0][0]
====================================================================================================
Total params: 252,219
Trainable params: 252,219
Non-trainable params: 0
____________________________________________________________________________________________________
None
Epoch 1/5
19200/19200 [==============================] - 795s - loss: 0.0292 - val_loss: 0.0128
Epoch 2/5
19200/19200 [==============================] - 754s - loss: 0.0169 - val_loss: 0.0120
Epoch 3/5
19200/19200 [==============================] - 753s - loss: 0.0161 - val_loss: 0.0114
Epoch 4/5
19200/19200 [==============================] - 723s - loss: 0.0154 - val_loss: 0.0100
Epoch 5/5
19200/19200 [==============================] - 1597s - loss: 0.0151 - val_loss: 0.0098

两者都训练验证损失减少,这乍一看是个好消息。但是在第一个 epoch 中,训练损失怎么会这么低呢?验证损失怎么能更低呢?这是否表明我的模型或训练设置中存在系统错误?

【问题讨论】:

    标签: python machine-learning neural-network deep-learning keras


    【解决方案1】:

    实际上 - 小于训练损失的验证损失并不像人们想象的那么罕见。它可能会发生,例如当验证数据中的所有示例都被您的训练集中的示例很好地覆盖,并且您的网络只是学习了数据集的实际结构。

    当您的数据结构不是很复杂时,这种情况经常发生。实际上 - 在第一个 epoch 之后损失的小值让您感到惊讶,这可能是您的情况发生这种情况的线索。

    就损失而言,损失很小-您尚未指定损失是多少,但假设您的任务是回归-我猜是mse-在这种情况下,是@级别的均方误差987654322@ 表示真实值和实际值之间的平均欧几里得距离等于0.1 什么是5% 的直径设置[-1, 1]。所以 - 这个错误真的这么小吗?

    您还没有指定在一个时期内分析的批次数。也许如果您的数据结构没有那么复杂并且批量很小 - 一个时期就足以很好地学习您的数据。

    为了检查您的模型是否训练有素,我建议您在绘制 y_pred 时绘制 correlation plot,例如X 轴和 Y 轴上的 y_true。然后你会真正看到你的模型是如何被训练的。

    编辑:正如 Neil 所提到的 - 小的验证错误背后可能还有更多原因 - 比如没有很好地分离案例。我还要补充一点——因为事实上——5 个时期不超过 90 分钟——也许最好通过使用经典的交叉验证模式来检查模型的结果,例如5折。这将向您保证,对于您的数据集 - 您的模型表现良好。

    【讨论】:

    • 感谢您的洞察力。你是对的:我正在使用 mse。批量大小为 128。
    • 我又给了你一个提示。您可以将此情节添加到您的帖子中。
    • 值得注意的是,验证分数异常低的一个可能原因是训练与 cv 样本的分离不佳。例如,如果输入是图像,并且在相似场景中拍摄了多张图像(或者您在 拆分为 train/cv 之前使用数据增强),那么您的 cv 集可能与训练过于相似,并且您会变得不准确简历结果。 OP的帖子没有直接表明这一点,但这是需要检查和防范的事情。解决方法是确保您将相关示例放在一起(按集合) - 所有示例都应放在 train 或 cv 集中。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2019-09-06
    • 1970-01-01
    • 2021-12-12
    • 2018-06-21
    • 1970-01-01
    • 2016-12-20
    • 2020-10-17
    相关资源
    最近更新 更多