schedulers.py 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. from paddle.optimizer import lr
  2. import logging
  3. __all__ = ["Polynomial"]
  4. class Polynomial(object):
  5. """
  6. Polynomial learning rate decay
  7. Args:
  8. learning_rate (float): The initial learning rate. It is a python float number.
  9. epochs(int): The decay epoch size. It determines the decay cycle, when by_epoch is set to true, it will change to epochs=epochs*step_each_epoch.
  10. step_each_epoch: all steps in each epoch.
  11. end_lr(float, optional): The minimum final learning rate. Default: 0.0001.
  12. power(float, optional): Power of polynomial. Default: 1.0.
  13. warmup_epoch(int): The epoch numbers for LinearWarmup. Default: 0, , when by_epoch is set to true, it will change to warmup_epoch=warmup_epoch*step_each_epoch.
  14. warmup_start_lr(float): Initial learning rate of warm up. Default: 0.0.
  15. last_epoch (int, optional): The index of last epoch. Can be set to restart training. Default: -1, means initial learning rate.
  16. by_epoch: Whether the set parameter is based on epoch or iter, when set to true,, epochs and warmup_epoch will be automatically multiplied by step_each_epoch. Default: True
  17. """
  18. def __init__(
  19. self,
  20. learning_rate,
  21. epochs,
  22. step_each_epoch,
  23. end_lr=0.0,
  24. power=1.0,
  25. warmup_epoch=0,
  26. warmup_start_lr=0.0,
  27. last_epoch=-1,
  28. by_epoch=True,
  29. **kwargs,
  30. ):
  31. super().__init__()
  32. if warmup_epoch >= epochs:
  33. msg = f'When using warm up, the value of "epochs" must be greater than value of "Optimizer.lr.warmup_epoch". The value of "Optimizer.lr.warmup_epoch" has been set to {epochs}.'
  34. logging.warning(msg)
  35. warmup_epoch = epochs
  36. self.learning_rate = learning_rate
  37. self.epochs = epochs
  38. self.end_lr = end_lr
  39. self.power = power
  40. self.last_epoch = last_epoch
  41. self.warmup_epoch = warmup_epoch
  42. self.warmup_start_lr = warmup_start_lr
  43. if by_epoch:
  44. self.epochs *= step_each_epoch
  45. self.warmup_epoch = int(self.warmup_epoch * step_each_epoch)
  46. def __call__(self):
  47. learning_rate = (
  48. lr.PolynomialDecay(
  49. learning_rate=self.learning_rate,
  50. decay_steps=self.epochs,
  51. end_lr=self.end_lr,
  52. power=self.power,
  53. last_epoch=self.last_epoch,
  54. )
  55. if self.epochs > 0
  56. else self.learning_rate
  57. )
  58. if self.warmup_epoch > 0:
  59. learning_rate = lr.LinearWarmup(
  60. learning_rate=learning_rate,
  61. warmup_steps=self.warmup_epoch,
  62. start_lr=self.warmup_start_lr,
  63. end_lr=self.learning_rate,
  64. last_epoch=self.last_epoch,
  65. )
  66. return learning_rate