-
Notifications
You must be signed in to change notification settings - Fork 5
/
experiment.py
129 lines (94 loc) · 3.72 KB
/
experiment.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
"""
This script shows an example of how to run a simple computational experiment. The research
question is as follows:
What is the value of not moving, ie. not sending a fleet out, but letting your ships build up.
As a first step towards answering this question, we will make two assumptions:
1) Players have two options: attack randomly, or don't move
2) Players decide between these two entirely at random
Under these simplified circumstances, how often should players decide not to move? This is a simple question
to answer, we simply build rand bots for a range of parameters, and play a few games for each
combination. We plot the resulrts in a heat map
"""
import matplotlib as mpl
mpl.use('Agg')
from matplotlib import pyplot as plt
from api import State
import random
# Define the bot:
# (we're not using it with the command line tools, so we can just put it here)
class Bot:
# Probability of not moving
__nomove = 0.0
def __init__(self, nomove=0.0):
self.__nomove = nomove
def get_move(self, state):
if random.random() < self.__nomove:
# IMPLEMENT: Make no move
pass
#IMPLEMENT: Make a random move (but not None).
pass
def empty(n):
"""
:param n: Size of the matrix to return
:return: n by n matrix (2D array) filled with 0s
"""
return [[0 for i in range(n)] for j in range(n)]
# For experiments, it's good to have repeatability, so we set the seed of the random number generator to a known value.
# That way, if something interesting happens, we can always rerun the exact same experiment
seed = random.randint(1, 1000)
print('Using seed {}.'.format(seed))
random.seed(seed)
# Parameters of our experiment
STEPS = 10
REPEATS = 5
MAX_TURNS = 100
inc = 1.0/STEPS
# Make empty matrices to count how many times each player won for a given
# combination of parameters
won_by_1 = empty(STEPS)
won_by_2 = empty(STEPS)
# We will move through the parameters from 0 to 1 in STEPS steps, and play REPEATS games for each
# combination. If at combination (i, j) player 1 winds a game, we increment won_by_1[i][j]
for i in range(STEPS):
for j in range(STEPS):
for r in range(REPEATS):
# Make the players
player1 = Bot(inc * i)
player2 = Bot(inc * j)
state, id = State.generate(6)
# play the game
while not state.finished():
player = player1 if state.whose_turn() == 1 else player2
state = state.next(player.get_move(state))
if state.turn_nr() > MAX_TURNS:
break
if state.finished():
if state.winner() == 1:
won_by_1[i][j] += 1
else:
won_by_2[i][j] += 1
print('finished {} vs {}'.format(inc * i, inc * j))
# This
result = [[0 for i in range(STEPS)] for j in range(STEPS)]
extreme = float('-inf')
for i in range(STEPS):
for j in range(STEPS):
# How many more games player 1 won than player 2
result[i][j] = float(won_by_1[i][j] - won_by_2[i][j])
# Find the largest absolute value
extreme = max(extreme, abs(result[i][j]))
# Plot the data as a heatmap
plt.imshow(
result,
extent=(0,1,0,1), # fit it to the square from (0,0) to (1,1)
vmin=-extreme, # give this value the lowest color (blue)
vmax=extreme, # give this value the higest color (red)
interpolation='nearest', # don't smooth the colors
origin='lower') # put the rsult[0][0] in the bottem left corner
# Always label your axes
plt.xlabel('player 1 nomove probability')
plt.ylabel('player 2 nomove probability')
# Set the red/blue colormap
plt.set_cmap('bwr')
plt.colorbar()
plt.savefig('experiment.pdf')