optimizer.py 1.9 KB
Newer Older
L
LDOUBLEV 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
#copyright (c) 2020 PaddlePaddle Authors. All Rights Reserve.
#
#Licensed under the Apache License, Version 2.0 (the "License");
#you may not use this file except in compliance with the License.
#You may obtain a copy of the License at
#
#    http://www.apache.org/licenses/LICENSE-2.0
#
#Unless required by applicable law or agreed to in writing, software
#distributed under the License is distributed on an "AS IS" BASIS,
#WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
#See the License for the specific language governing permissions and
#limitations under the License.
from __future__ import absolute_import
from __future__ import division
from __future__ import print_function
import paddle.fluid as fluid
littletomatodonkey's avatar
littletomatodonkey 已提交
18 19
from paddle.fluid.regularizer import L2Decay

T
tink2123 已提交
20 21 22
from ppocr.utils.utility import initial_logger

logger = initial_logger()
L
LDOUBLEV 已提交
23 24 25 26 27 28 29 30 31 32 33 34 35


def AdamDecay(params, parameter_list=None):
    """
    define optimizer function
    args:
        params(dict): the super parameters
        parameter_list (list): list of Variable names to update to minimize loss
    return:
    """
    base_lr = params['base_lr']
    beta1 = params['beta1']
    beta2 = params['beta2']
littletomatodonkey's avatar
littletomatodonkey 已提交
36 37
    l2_decay = params.get("l2_decay", 0.0)

T
tink2123 已提交
38 39 40 41 42 43 44 45 46 47
    if 'decay' in params:
        params = params['decay']
        decay_mode = params['function']
        step_each_epoch = params['step_each_epoch']
        total_epoch = params['total_epoch']
        if decay_mode == "cosine_decay":
            base_lr = fluid.layers.cosine_decay(
                learning_rate=base_lr,
                step_each_epoch=step_each_epoch,
                epochs=total_epoch)
T
tink2123 已提交
48 49
        else:
            logger.info("Only support Cosine decay currently")
L
LDOUBLEV 已提交
50 51 52 53
    optimizer = fluid.optimizer.Adam(
        learning_rate=base_lr,
        beta1=beta1,
        beta2=beta2,
littletomatodonkey's avatar
littletomatodonkey 已提交
54
        regularization=L2Decay(regularization_coeff=l2_decay),
L
LDOUBLEV 已提交
55 56
        parameter_list=parameter_list)
    return optimizer