This is a Python 3-only library. A shebang with `#!/usr/bin/env python` will launch python2 on many systems which do not have python3 installed. Setting the shebang to `#!/usr/bin/env python3` will show a useful error on systems without Python 3.
55 lines
1.8 KiB
Python
55 lines
1.8 KiB
Python
#!/usr/bin/env python3
|
|
|
|
from mpi4py import MPI
|
|
from baselines.common import set_global_seeds
|
|
from baselines import bench
|
|
import os.path as osp
|
|
import gym, logging
|
|
from baselines import logger
|
|
from baselines.common.atari_wrappers import make_atari, wrap_deepmind
|
|
|
|
def train(env_id, num_timesteps, seed):
|
|
from baselines.ppo1 import pposgd_simple, cnn_policy
|
|
import baselines.common.tf_util as U
|
|
rank = MPI.COMM_WORLD.Get_rank()
|
|
sess = U.single_threaded_session()
|
|
sess.__enter__()
|
|
if rank == 0:
|
|
logger.configure()
|
|
else:
|
|
logger.configure(format_strs=[])
|
|
workerseed = seed + 10000 * MPI.COMM_WORLD.Get_rank()
|
|
set_global_seeds(workerseed)
|
|
env = make_atari(env_id)
|
|
def policy_fn(name, ob_space, ac_space): #pylint: disable=W0613
|
|
return cnn_policy.CnnPolicy(name=name, ob_space=ob_space, ac_space=ac_space)
|
|
env = bench.Monitor(env, logger.get_dir() and
|
|
osp.join(logger.get_dir(), str(rank)))
|
|
env.seed(workerseed)
|
|
gym.logger.setLevel(logging.WARN)
|
|
|
|
env = wrap_deepmind(env)
|
|
env.seed(workerseed)
|
|
|
|
pposgd_simple.learn(env, policy_fn,
|
|
max_timesteps=int(num_timesteps * 1.1),
|
|
timesteps_per_actorbatch=256,
|
|
clip_param=0.2, entcoeff=0.01,
|
|
optim_epochs=4, optim_stepsize=1e-3, optim_batchsize=64,
|
|
gamma=0.99, lam=0.95,
|
|
schedule='linear'
|
|
)
|
|
env.close()
|
|
|
|
def main():
|
|
import argparse
|
|
parser = argparse.ArgumentParser(formatter_class=argparse.ArgumentDefaultsHelpFormatter)
|
|
parser.add_argument('--env', help='environment ID', default='PongNoFrameskip-v4')
|
|
parser.add_argument('--seed', help='RNG seed', type=int, default=0)
|
|
parser.add_argument('--num-timesteps', type=int, default=int(10e6))
|
|
args = parser.parse_args()
|
|
train(args.env, num_timesteps=args.num_timesteps, seed=args.seed)
|
|
|
|
if __name__ == '__main__':
|
|
main()
|