args.py 3.2 KB
Newer Older
P
phlrain 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
#   Copyright (c) 2018 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 argparse
import distutils.util


23 24 25 26 27 28 29 30 31
def str2bool(v):
    if v.lower() in ('yes', 'true', 't', 'y', '1'):
        return True
    elif v.lower() in ('no', 'false', 'f', 'n', '0'):
        return False
    else:
        raise argparse.ArgumentTypeError('Unsupported value encountered.')


P
phlrain 已提交
32 33 34 35 36 37
def parse_args():
    parser = argparse.ArgumentParser(description=__doc__)
    parser.add_argument(
        "--model_type",
        type=str,
        default="small",
L
liuhongyu 已提交
38 39 40 41 42
        help="model_type [test|small|medium|large]")
    parser.add_argument(
        "--rnn_model",
        type=str,
        default="static",
H
Hongyu Liu 已提交
43
        help="model_type [static|padding|cudnn|basic_lstm]")
P
phlrain 已提交
44 45 46 47
    parser.add_argument(
        "--data_path", type=str, help="all the data for train,valid,test")
    parser.add_argument('--para_init', action='store_true')
    parser.add_argument(
48 49 50 51 52 53 54 55 56
        '--use_gpu',
        type=str2bool,
        default=False,
        help='Whether using gpu [True|False]')
    parser.add_argument(
        '--parallel',
        type=str2bool,
        default=True,
        help='Whether using gpu in parallel [True|False]')
57 58 59 60 61
    parser.add_argument(
        '--profile',
        type=str2bool,
        default=False,
        help='Whether profiling the trainning [True|False]')
62 63 64 65 66 67
    parser.add_argument(
        '--enable_auto_fusion',
        type=str2bool,
        default=False,
        help='Whether enable fusion_group [True|False]. It is a experimental feature.'
    )
68
    parser.add_argument(
69
        '--use_dataloader',
70 71
        type=str2bool,
        default=False,
72
        help='Whether using dataloader to feed data [True|False]')
P
phlrain 已提交
73 74 75
    parser.add_argument(
        '--log_path',
        help='path of the log file. If not set, logs are printed to console')
76 77 78 79 80
    parser.add_argument(
        '--save_model_dir',
        type=str,
        default="models",
        help='dir of the saved model.')
81 82 83 84 85
    parser.add_argument(
        '--init_from_pretrain_model',
        type=str,
        default=None,
        help='dir to init model.')
P
phlrain 已提交
86
    parser.add_argument('--enable_ce', action='store_true')
87 88
    parser.add_argument('--batch_size', type=int, default=0, help='batch size')
    parser.add_argument('--max_epoch', type=int, default=0, help='max epoch')
89

90
    # NOTE: args for profiler, used for benchmark
91 92 93 94 95
    parser.add_argument(
        '--profiler_path',
        type=str,
        default='/tmp/paddingrnn.profile',
        help='the profiler output file path. used for benchmark')
P
phlrain 已提交
96 97
    args = parser.parse_args()
    return args