【发布时间】:2021-06-25 03:22:27
【问题描述】:
据我了解,model.fit(epochs=NUM_EPOCHS) 不会重置每个时期的指标。我的 metrics 和 model.fit() 代码如下所示(简化):
import tensorflow as tf
from tensorflow.keras import applications
NUM_CLASSES = 4
INPUT_SHAPE = (256, 256, 3)
MODELS = {
'DenseNet121': applications.DenseNet121,
'DenseNet169': applications.DenseNet169
}
REDUCE_LR_PATIENCE = 2
REDUCE_LR_FACTOR = 0.7
EARLY_STOPPING_PATIENCE = 4
for modelName, model in MODELS.items():
loadedModel = model(include_top=False, weights='imagenet',
pooling='avg', input_shape=INPUT_SHAPE)
sequentialModel = tf.keras.models.Sequential()
sequentialModel.add(loadedModel)
sequentialModel.add(tf.keras.layers.Dense(NUM_CLASSES, activation='softmax'))
aucCurve = tf.keras.metrics.AUC(curve = 'ROC', multi_label = True)
categoricalAccuracy = tf.keras.metrics.CategoricalAccuracy()
F1Score = tfa.metrics.F1Score(num_classes = NUM_CLASSES, average = 'macro', threshold = None)
metrics = [aucCurve, categoricalAccuracy, F1Score]
sequentialModel.compile(metrics=metrics)
callbacks = [
tf.keras.callbacks.ReduceLROnPlateau(monitor='val_loss', patience=REDUCE_LR_PATIENCE, verbose=1, factor=REDUCE_LR_FACTOR),
tf.keras.callbacks.EarlyStopping(monitor='val_loss', verbose=1, patience=EARLY_STOPPING_PATIENCE),
tf.keras.callbacks.ModelCheckpoint(filepath=modelName + '_epoch-{epoch:02d}.h5', monitor='val_loss', save_best_only=False, verbose=1),
tf.keras.callbacks.CSVLogger(modelName + '_training.csv')]
sequentialModel.fit(epochs=NUM_EPOCHS)
也许我可以通过在 NUM_EPOCHS 范围内执行 for 循环来重置指标,并在 for 循环中初始化指标,但我不确定这是否是一个好的解决方案。另外,我有 ModelCheckpoint 和 CSVLogger 回调,它们需要来自 model.fit() 的纪元数,所以如果我执行 for 循环,它就不会真正起作用。
您对如何重置每个时期的指标有什么建议吗?在 NUM_EPOCHS 范围内执行 for 循环是这里唯一的解决方案吗?谢谢。
【问题讨论】:
标签: python machine-learning keras metrics