forked from lukearcus/GeneralSumOBL
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.py
44 lines (39 loc) · 1.66 KB
/
main.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
from agents.players import *
import agents.learners as learners
from UI.plot_funcs import plot_everything
import UI.get_args as get_args
from functions import *
import numpy as np
import sys
import time
import logging
from multiprocessing import Pool
import OBL
import FSP
log = logging.getLogger(__name__)
NUM_LOOPS=10 # Change this to run multiple seeds (in parallel)
def main():
options = get_args.run()
if options["mode"] == "obl":
with Pool(NUM_LOOPS) as p:
args = [options for _ in range(NUM_LOOPS)]
all_res = p.map(OBL.run, args)
# all_res = OBL.run(options)
#plot_everything(pol_plot, bel_plot, "kuhn", reward_hist[-1], exploitability)
log.info("Saving results...")
filename = "results/" + options["game_name"] + "_" + options["learner_type"] + "_lvls" + str(options["num_lvls"]) + "_bridge" + str(options["bridge_len"]) + "_loops"+str(NUM_LOOPS)
np.savez(filename, res=all_res)
#np.savez(filename, pols=pol_plot, bels=bel_plot, exploit=exploitability, rewards=reward_hist, times=times)
log.info("Completed")
return 0
else:
with Pool(NUM_LOOPS) as p:
all_res = p.map(FSP.run, [options for _ in range(NUM_LOOPS)])
log.info("Saving results...")
filename = "results/" + options["game_name"] + "_FSP" + "_lvls" + str(options["num_lvls"]) + "_bridge" + str(options["bridge_len"]) + "_loops"+str(NUM_LOOPS)
np.savez(filename, res=all_res)
#np.savez(filename, pols=pol_plot, bels=bel_plot, exploit=exploitability, rewards=reward_hist, times=times)
log.info("Completed")
return 0
if __name__=="__main__":
main()