-
Notifications
You must be signed in to change notification settings - Fork 7
/
train_rl_agents.py
132 lines (112 loc) · 4.08 KB
/
train_rl_agents.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
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
import os
import argparse
import itertools
from multiprocessing import Pool
import json
from datetime import datetime
import numpy as np
from marinenav_env.envs.marinenav_env import MarineNavEnv2
from policy.agent import Agent
from policy.trainer import Trainer
parser = argparse.ArgumentParser(description="Train IQN model")
parser.add_argument(
"-C",
"--config-file",
dest="config_file",
type=open,
required=True,
help="configuration file for training parameters",
)
parser.add_argument(
"-P",
"--num-procs",
dest="num_procs",
type=int,
default=1,
help="number of subprocess workers to use for trial parallelization",
)
parser.add_argument(
"-D",
"--device",
dest="device",
type=str,
default="cpu",
help="device to run all subprocesses, could only specify 1 device in each run"
)
def product(*args, repeat=1):
# This function is a modified version of
# https://docs.python.org/3/library/itertools.html#itertools.product
pools = [tuple(pool) for pool in args] * repeat
result = [[]]
for pool in pools:
result = [x+[y] for x in result for y in pool]
for prod in result:
yield tuple(prod)
def trial_params(params):
if isinstance(params,(str,int,float)):
return [params]
elif isinstance(params,list):
return params
elif isinstance(params, dict):
keys, vals = zip(*params.items())
mix_vals = []
for val in vals:
val = trial_params(val)
mix_vals.append(val)
return [dict(zip(keys, mix_val)) for mix_val in itertools.product(*mix_vals)]
else:
raise TypeError("Parameter type is incorrect.")
def params_dashboard(params):
print("\n====== Training Setup ======\n")
print("seed: ",params["seed"])
print("total_timesteps: ",params["total_timesteps"])
print("eval_freq: ",params["eval_freq"])
print("use_iqn: ",params["use_iqn"])
print("\n")
def run_trial(device,params):
exp_dir = os.path.join(params["save_dir"],
"training_"+params["training_time"],
"seed_"+str(params["seed"]))
os.makedirs(exp_dir)
param_file = os.path.join(exp_dir,"trial_config.json")
with open(param_file, 'w+') as outfile:
json.dump(params, outfile)
train_env = MarineNavEnv2(seed=params["seed"],schedule=params["training_schedule"])
eval_env = MarineNavEnv2(seed=253)
cooperative_agent = Agent(cooperative=True,device=device,use_iqn=params["use_iqn"],seed=params["seed"]+100)
if "load_model" in params:
cooperative_agent.load_model(params["load_model"],"cooperative",device)
trainer = Trainer(train_env=train_env,
eval_env=eval_env,
eval_schedule=params["eval_schedule"],
cooperative_agent=cooperative_agent,
non_cooperative_agent=None,
)
trainer.save_eval_config(exp_dir)
trainer.learn(total_timesteps=params["total_timesteps"],
eval_freq=params["eval_freq"],
eval_log_path=exp_dir)
if __name__ == "__main__":
args = parser.parse_args()
params = json.load(args.config_file)
params_dashboard(params)
training_schedule = params.pop("training_schedule")
eval_schedule = params.pop("eval_schedule")
trial_param_list = trial_params(params)
dt = datetime.now()
timestamp = dt.strftime("%Y-%m-%d-%H-%M-%S")
if args.num_procs == 1:
for param in trial_param_list:
param["training_time"]=timestamp
param["training_schedule"]=training_schedule
param["eval_schedule"]=eval_schedule
run_trial(args.device,param)
else:
with Pool(processes=args.num_procs) as pool:
for param in trial_param_list:
param["training_time"]=timestamp
param["training_schedule"]=training_schedule
param["eval_schedule"]=eval_schedule
pool.apply_async(run_trial,(args.device,param))
pool.close()
pool.join()