ray/rllib/scripts.py

39 lines
1.2 KiB
Python
Raw Normal View History

2018-07-12 19:12:04 +02:00
#!/usr/bin/env python
import argparse
from ray.rllib import train
from ray.rllib import rollout
EXAMPLE_USAGE = """
Example usage for training:
rllib train --run DQN --env CartPole-v0
Example usage for rollout:
rllib rollout /trial_dir/checkpoint_000001/checkpoint-1 --run DQN
2018-07-12 19:12:04 +02:00
"""
def cli():
parser = argparse.ArgumentParser(
description="Train or Run an RLlib Trainer.",
2018-07-12 19:12:04 +02:00
formatter_class=argparse.RawDescriptionHelpFormatter,
epilog=EXAMPLE_USAGE)
subcommand_group = parser.add_subparsers(
help="Commands to train or run an RLlib agent.", dest="command")
# see _SubParsersAction.add_parser in
# https://github.com/python/cpython/blob/master/Lib/argparse.py
train_parser = train.create_parser(
lambda **kwargs: subcommand_group.add_parser("train", **kwargs))
rollout_parser = rollout.create_parser(
lambda **kwargs: subcommand_group.add_parser("rollout", **kwargs))
options = parser.parse_args()
if options.command == "train":
train.run(options, train_parser)
elif options.command == "rollout":
rollout.run(options, rollout_parser)
else:
parser.print_help()