在sgd中打印学习率evary epoch

时间:2016-10-20 03:14:18

标签: python deep-learning keras

我尝试在小批量梯度下降中打印学习率。但是对于许多时代而言,Ir保持不变(总是0.10000000149)。但它被要求改变废弃的小批量。代码如下:

# set the decay as 1e-1 to see the Ir change between epochs.
sgd = SGD(lr=0.1, decay=1e-1, momentum=0.9, nesterov=True)
model.compile(loss='categorical_crossentropy',
              optimizer=sgd,
              metrics=['accuracy'])
class LossHistory(Callback):
    def on_epoch_begin(self, batch, logs={}):
        lr=self.model.optimizer.lr.get_value()
        print('Ir:', lr)
history=LossHistory()
model.fit(X_train, Y_train,
          batch_size= batch_size,
          nb_epoch= nb_epoch,
          callbacks= [history])

2 个答案:

答案 0 :(得分:1)

您要打印的是初始学习率,而不是实际计算的学习率:

lr = self.lr * (1. / (1. + self.decay * self.iterations))

答案 1 :(得分:1)

from keras import backend as K
from keras.callbacks import Callback


class SGDLearningRateTracker(Callback):
    def on_epoch_end(self, epoch, logs={}):
        optimizer = self.model.optimizer
        lr = K.eval(optimizer.lr * (1. / (1. + optimizer.decay * optimizer.iterations)))
        print('\nLR: {:.6f}\n'.format(lr))

然后在你的模型中添加回调:

model.fit(X_train, Y_train_cat, nb_epoch=params['n_epochs'], batch_size=params['batch_size'], validation_split=0.1,callbacks=[SGDLearningRateTracker()])