-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtrain.py
109 lines (91 loc) · 4.11 KB
/
train.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
"""
file: train.py
module used to launch adgs and dgs for training neural networks
to solve reinforcement learning tasks.
"""
import argparse
from mpi4py import MPI
from algorithms.asgf import asgf_parallel_train
from algorithms.dgs import dgs_parallel_train
from algorithms.es import es_parallel_train
from algorithms.cma import cma_train
def get_maxiter(env_name):
"""get the maximum number of iterations to run the solver
for a reinforceemnt learning environment problem
"""
DEFAULT_ITS = 200
max_its = {
'Pendulum-v0':200,
'InvertedPendulumBulletEnv-v0':100,
'Acrobot-v1':200,
'CartPole-v1':100,
'MountainCarContinuous-v0':100,
'HopperBulletEnv-v0':400,
'ReacherBulletEnv-v0':150,
}
try:
its = max_its[env_name]
except:
print(f"No default number of iterations for {env_name}. Using 200.")
its = DEFAULT_ITS
return its
if __name__ == "__main__":
# get arguements
parser = argparse.ArgumentParser(description='Get problem set up variables.')
# environment name
parser.add_argument('--env_name',
help='name of openAI gym environment')
# algorihtm
parser.add_argument('--algo',
default='asgf',
help='name of algorithm to use. Either dgs or asgf.')
# RNG seed
parser.add_argument('--seed',
default=0,
help='value of random seed used for environment')
# hidden layer sizes
parser.add_argument('--hidden_sizes',
type=lambda x: [int(item) for item in x.split(',')],
default=[8,8],
help='list of ints for hidden layer sizes')
# policy mode
parser.add_argument('--policy_mode',
default='deterministic',
help='mode by which agent chooses actions. either prob or deterministic.')
# parse arguments
args = parser.parse_args()
# get maximum number of iterations
maxiter = get_maxiter(args.env_name)
# set up comm world and get rank
comm = MPI.COMM_WORLD
size = comm.Get_size()
rank = comm.Get_rank()
if rank == 0 and args.algo in ['asgf', 'dgs', 'es', 'cma']:
print(f"Begin training for {args.env_name} using {args.algo} with {size} workers")
if args.algo == 'asgf':
asgf_parallel_train(rank, int(args.seed), args.env_name, maxiter,
hidden_layers=args.hidden_sizes, policy_mode=args.policy_mode)
elif args.algo == 'dgs':
dgs_parallel_train(rank, int(args.seed), args.env_name, maxiter,
hidden_layers=args.hidden_sizes, policy_mode=args.policy_mode)
elif args.algo == 'es':
es_parallel_train(rank, int(args.seed), args.env_name, maxiter,
hidden_layers=args.hidden_sizes, policy_mode=args.policy_mode)
elif args.algo == 'cma':
cma_train(rank, int(args.seed), args.env_name, maxiter,
hidden_layers=args.hidden_sizes, policy_mode=args.policy_mode)
else:
raise SystemExit('algorithm {:s} is not recognized, supported algorithms are:'\
' asgf, dgs, es, cma'.format(args.algo))
# exp_num = 10
# for s in range(1, exp_num+1):
# if rank == 0:
# print('\nRunning experiment {:2d} / {:2d}'.format(s, exp_num))
# if args.algo == 'asgf':
# asgf_parallel_train(rank, s, args.env_name, maxiter, hidden_layers=args.hidden_sizes, policy_mode=args.policy_mode)
# elif args.algo == 'dgs':
# dgs_parallel_train(rank, s, args.env_name, maxiter, hidden_layers=args.hidden_sizes, policy_mode=args.policy_mode)
# elif args.algo == 'es':
# es_parallel_train(rank, s, args.env_name, maxiter, hidden_layers=args.hidden_sizes, policy_mode=args.policy_mode)
# elif args.algo == 'cma':
# cma_train(rank, s, args.env_name, maxiter, hidden_layers=args.hidden_sizes, policy_mode=args.policy_mode)