from __future__ import absolute_import from __future__ import division from __future__ import print_function import time import os import subprocess import distutils.util import numpy as np from paddle.fluid import core def print_arguments(args): """Print argparse's arguments. Usage: .. code-block:: python parser = argparse.ArgumentParser() parser.add_argument("name", default="Jonh", type=str, help="User name.") args = parser.parse_args() print_arguments(args) :param args: Input argparse.Namespace for printing. :type args: argparse.Namespace """ print("----------- Configuration Arguments -----------") for arg, value in sorted(vars(args).iteritems()): print("%s: %s" % (arg, value)) print("------------------------------------------------") def add_arguments(argname, type, default, help, argparser, **kwargs): """Add argparse's argument. Usage: .. code-block:: python parser = argparse.ArgumentParser() add_argument("name", str, "Jonh", "User name.", parser) args = parser.parse_args() """ type = distutils.util.strtobool if type == bool else type argparser.add_argument( "--" + argname, default=default, type=type, help=help + ' Default: %(default)s.', **kwargs) def fmt_time(): """ get formatted time for now """ now_str = time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(time.time())) return now_str def get_gpunum(): """ get number of gpu devices """ visibledevice = os.getenv('CUDA_VISIBLE_DEVICES') if visibledevice: devicenum = len(visibledevice.split(',')) else: devicenum = subprocess.check_output(['nvidia-smi', '-L']).count('\n') return devicenum