log_util.py 1.6 KB
Newer Older
1
# Copyright (c) 2021 PaddlePaddle Authors. All Rights Reserved.
2
#
3 4 5
# 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
6
#
7
#     http://www.apache.org/licenses/LICENSE-2.0
8
#
9 10 11 12 13 14 15 16 17
# 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.

import logging
import sys

18 19
__all__ = []

20 21

class LoggerFactory:
22

23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41
    @staticmethod
    def build_logger(name=None, level=logging.INFO):
        assert name is not None, "name for logger should not be None"

        formatter = logging.Formatter(
            "%(asctime)s-%(levelname)s: "
            "[%(filename)s:%(lineno)d:%(funcName)s] %(message)s")

        _logger = logging.getLogger(name)
        _logger.setLevel(level)
        _logger.propagate = False
        handler = logging.StreamHandler(stream=sys.stderr)
        handler.setFormatter(formatter)
        handler.setLevel(level)
        _logger.addHandler(handler)
        return _logger


logger = LoggerFactory.build_logger(name="HybridParallel", level=logging.INFO)
42 43 44 45 46 47 48 49 50 51 52 53 54


def layer_to_str(base, *args, **kwargs):
    name = base + "("
    if args:
        name += ", ".join(str(arg) for arg in args)
        if kwargs:
            name += ", "
    if kwargs:
        name += ", ".join("{}={}".format(key, str(value))
                          for key, value in kwargs.items())
    name += ")"
    return name