我知道如何save the model after every epoch:
savemodel = ModelCheckpoint(filepath='models/model_{epoch:02d}-{loss:.2f}.h5')
model.fit(X, Y, batch_size=4, epochs=32, verbose=1, callbacks=[savemodel])
如何具有自定义的回调函数来记录某些信息:
def write_metrics():
with open('log.txt', 'a') as f: # append to the log file
f.write('{epoch:02d}: loss = {loss:.1f}')
model.fit(X, Y, batch_size=4, epochs=32, verbose=1, callbacks=[savemodel, write_metrics])
?
使用此代码将无法正常工作,因为{loss}
中未定义{epoch}
和f.write('{epoch:02d}: loss = {loss:.1f}')
。
答案 0 :(得分:2)
这是解决方案,将Callback
子类化:
from keras.callbacks import Callback
class MyLogger(Callback):
def on_epoch_end(self, epoch, logs=None):
with open('log.txt', 'a+') as f:
f.write('%02d %.3f\n' % (epoch, logs['loss']))
然后
mylogger = MyLogger()
model.fit(X, Y, batch_size=32, epochs=32, verbose=1, callbacks=[mylogger])
甚至
model.fit(X, Y, batch_size=32, epochs=32, verbose=1, callbacks=[MyLogger()])
答案 1 :(得分:1)
实际上,您不需要为此定义一个函数(甚至使用显式回调),因为此类信息是由fit
方法自动返回的;来自docs:
历史
keras.callbacks.History()
将事件记录到
History
对象中的回调。此回调将自动应用于每个Keras模型。的
History
个模型方法会返回fit
个对象。
您甚至不需要显式导入任何内容;您需要的只是:
hist = model.fit(X, Y, batch_size=4, epochs=32, verbose=1, callbacks=[savemodel]) # no other specific callback
和hist.history
将在每个时期结束时包含损失和您可能已定义的,用于训练和验证(如果存在)的其他任何感兴趣的指标(例如,准确性)。保存到文件中。
有关详细示例,请参见here。