繁体   English   中英

如何在 TensorFlow 2.0 中降低 SGD 优化器的学习率?

[英]How to get reduced learning rate of SGD optimizer in TensorFlow 2.0?

我想在 tensorflow2.0 的 SGD 优化器中降低学习率,我使用了这行代码: tf.keras.optimizers.SGD(learning_rate, decay=lr_decay, momentum=0.9)但我不知道我的学习率是否有下降了,我怎样才能得到我当前的学习率?

print(model.optimizer._decayed_lr('float32').numpy())

会做。 _decayed_lr()将衰减的学习率计算为iterationsdecay的 function 。 下面的完整示例。


from tensorflow.keras.layers import Input, Dense
from tensorflow.keras.models import Model
from tensorflow.keras.optimizers import SGD
import numpy as np

ipt = Input((12,))
out = Dense(12)(ipt)
model = Model(ipt, out)
model.compile(SGD(1e-4, decay=1e-2), loss='mse')

x = y = np.random.randn(32, 12)  # dummy data
for iteration in range(10):
    model.train_on_batch(x, y)
    print("lr at iteration {}: {}".format(
            iteration + 1, model.optimizer._decayed_lr('float32').numpy()))
# OUTPUTS
lr at iteration 1: 9.900989971356466e-05
lr at iteration 2: 9.803921420825645e-05
lr at iteration 3: 9.708738070912659e-05
lr at iteration 4: 9.61538462433964e-05
lr at iteration 5: 9.523809421807528e-05
lr at iteration 6: 9.433962259208784e-05
lr at iteration 7: 9.345793660031632e-05
lr at iteration 8: 9.259258513338864e-05
lr at iteration 9: 9.174311708193272e-05
lr at iteration 10: 9.09090886125341e-05

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM