check.py 3.9 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25
# Copyright (c) 2019 PaddlePaddle Authors. All Rights Reserved.
#
# 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 sys

import paddle.fluid as fluid

import logging
logger = logging.getLogger(__name__)

26 27 28 29 30 31
__all__ = [
    'check_gpu',
    'check_version',
    'check_config',
    'check_py_func',
]
32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51


def check_gpu(use_gpu):
    """
    Log error and exit when set use_gpu=true in paddlepaddle
    cpu version.
    """
    err = "Config use_gpu cannot be set as true while you are " \
          "using paddlepaddle cpu version ! \nPlease try: \n" \
          "\t1. Install paddlepaddle-gpu to run model on GPU \n" \
          "\t2. Set use_gpu as false in config file to run " \
          "model on CPU"

    try:
        if use_gpu and not fluid.is_compiled_with_cuda():
            logger.error(err)
            sys.exit(1)
    except Exception as e:
        pass

W
wangguanzhong 已提交
52

53
def check_version(version='1.7.0'):
W
wangguanzhong 已提交
54 55 56 57
    """
    Log error and exit when the installed version of paddlepaddle is
    not satisfied.
    """
58
    err = "PaddlePaddle version {} or higher is required, " \
W
wangguanzhong 已提交
59
          "or a suitable develop version is satisfied as well. \n" \
60
          "Please make sure the version is good with your code.".format(version)
W
wangguanzhong 已提交
61 62

    try:
63
        fluid.require_version(version)
W
wangguanzhong 已提交
64 65 66
    except Exception as e:
        logger.error(err)
        sys.exit(1)
67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96


def check_config(cfg):
    """
    Check the correctness of the configuration file. Log error and exit
    when Config is not compliant.
    """
    err = "'{}' not specified in config file. Please set it in config file."
    check_list = ['architecture', 'num_classes']
    try:
        for var in check_list:
            if not var in cfg:
                logger.error(err.format(var))
                sys.exit(1)
    except Exception as e:
        pass

    if 'log_iter' not in cfg:
        cfg.log_iter = 20

    train_dataset = cfg['TrainReader']['dataset']
    eval_dataset = cfg['EvalReader']['dataset']
    test_dataset = cfg['TestReader']['dataset']
    assert train_dataset.with_background == eval_dataset.with_background, \
        "'with_background' of TrainReader is not equal to EvalReader."
    assert train_dataset.with_background == test_dataset.with_background, \
        "'with_background' of TrainReader is not equal to TestReader."

    actual_num_classes = int(cfg.num_classes) - int(
        train_dataset.with_background)
G
Guanghua Yu 已提交
97
    logger.debug("The 'num_classes'(number of classes) you set is {}, " \
98 99 100 101 102 103
                "and 'with_background' in 'dataset' sets {}.\n" \
                "So please note the actual number of categories is {}."
                .format(cfg.num_classes, train_dataset.with_background,
                    actual_num_classes))

    return cfg
104 105 106 107 108 109 110 111 112 113 114 115 116 117


def check_py_func(program):
    for block in program.blocks:
        for op in block.ops:
            if op.type == 'py_func':
                input_arg = op.input_arg_names
                output_arg = op.output_arg_names
                err = "The program contains py_func with input: {}, "\
                      "output: {}. It is not supported in Paddle inference "\
                      "engine. please replace it by paddle ops. For example, "\
                      "if you use MultiClassSoftNMS, better to replace it by "\
                      "MultiClassNMS.".format(input_arg, output_arg)
                raise Exception(err)