import argparse def default_argument_parser(): r"""A simple yet genral argument parser for experiments with parakeet. This is used in examples with parakeet. And it is intended to be used by other experiments with parakeet. It requires a minimal set of command line arguments to start a training script. The ``--config`` and ``--opts`` are used for overwrite the deault configuration. The ``--data`` and ``--output`` specifies the data path and output path. Resuming training from existing progress at the output directory is the intended default behavior. The ``--checkpoint_path`` specifies the checkpoint to load from. The ``--device`` and ``--nprocs`` specifies how to run the training. See Also -------- parakeet.training.experiment Returns ------- argparse.ArgumentParser the parser """ parser = argparse.ArgumentParser() # yapf: disable # data and outpu parser.add_argument("--config", metavar="FILE", help="path of the config file to overwrite to default config with.") parser.add_argument("--data", metavar="DATA_DIR", help="path to the datatset.") parser.add_argument("--output", metavar="OUTPUT_DIR", help="path to save checkpoint and logs.") # load from saved checkpoint parser.add_argument("--checkpoint_path", type=str, help="path of the checkpoint to load") # running parser.add_argument("--device", type=str, choices=["cpu", "gpu"], help="device type to use, cpu and gpu are supported.") parser.add_argument("--nprocs", type=int, default=1, help="number of parallel processes to use.") # overwrite extra config and default config parser.add_argument("--opts", nargs=argparse.REMAINDER, help="options to overwrite --config file and the default config, passing in KEY VALUE pairs") # yapd: enable return parser