-
Notifications
You must be signed in to change notification settings - Fork 53
/
Copy pathrun.py
executable file
·117 lines (99 loc) · 3.6 KB
/
run.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
#!/usr/bin/env python2
import os
import ast
import argparse
import itertools
_is_multiprocessing_supported = True
try:
from multiprocessing import Pool
except ImportError:
_is_multiprocessing_supported = False # the OS does not support it. See http://bugs.python.org/issue3770
###
import game
from settings import settings
parser = argparse.ArgumentParser(description="Robot game execution script.")
parser.add_argument("usercode1",
help="File containing first robot class definition.")
parser.add_argument("usercode2",
help="File containing second robot class definition.")
parser.add_argument("-m", "--map", help="User-specified map file.",
default=os.path.join(os.path.dirname(__file__), 'maps/default.py'))
parser.add_argument("-c", "--count", type=int,
default=1,
help="Game count, default: 1")
parser.add_argument("-A", "--no-animate", action="store_false",
default=True,
help="Disable animations in rendering.")
group = parser.add_mutually_exclusive_group()
group.add_argument("-H", "--headless", action="store_true",
default=False,
help="Disable rendering game output.")
group.add_argument("-T", "--play-in-thread", action="store_true",
default=False,
help="Separate GUI thread from the one which computes robot moves.")
def make_player(fname):
with open(fname) as player_code:
return game.Player(player_code.read())
def play(players, print_info=True, animate_render=True, play_in_thread=False):
if play_in_thread:
g = game.ThreadedGame(*players, print_info=print_info,
record_actions=True, record_history = True)
else:
g = game.Game(*players, print_info=print_info, record_actions=True,
record_history = True)
if print_info:
# only import render if we need to render the game;
# this way, people who don't have tkinter can still
# run headless
import render
g.run_all_turns()
render.Render(g, game.settings, animate_render)
print g.history
return g.get_scores()
def test_runs_sequentially(args):
players = [make_player(args.usercode1), make_player(args.usercode2)]
scores = []
for i in xrange(args.count):
scores.append(
play(players, not args.headless, args.no_animate, args.play_in_thread)
)
print scores[-1]
return scores
def task(data):
usercode1, usercode2, headless, no_animate, play_in_thread = data
result = play(
[
make_player(usercode1),
make_player(usercode2)
],
not headless,
no_animate,
play_in_thread,
)
print result
return result
def test_runs_concurrently(args):
data = itertools.repeat(
[
args.usercode1,
args.usercode2,
args.headless,
args.no_animate,
args.play_in_thread,
],
args.count
)
return Pool().map(task, data, 1)
if __name__ == '__main__':
args = parser.parse_args()
map_name = os.path.join(args.map)
map_data = ast.literal_eval(open(map_name).read())
game.init_settings(map_data)
runner = test_runs_sequentially
if _is_multiprocessing_supported and args.count > 1:
runner = test_runs_concurrently
scores = runner(args)
if args.count > 1:
p1won = sum(p1 > p2 for p1, p2 in scores)
p2won = sum(p2 > p1 for p1, p2 in scores)
print [p1won, p2won, args.count - p1won - p2won]