forked from karinemiras/evoman_framework
-
Notifications
You must be signed in to change notification settings - Fork 1
/
demo_controller.py
124 lines (96 loc) · 3.5 KB
/
demo_controller.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
from controller import Controller
import numpy as np
def sigmoid_activation(x):
return 1./(1.+np.exp(-x))
# implements controller structure for player
class player_controller(Controller):
def __init__(self, _n_hidden):
# Number of hidden neurons
self.n_hidden = [_n_hidden]
def control(self, inputs, controller):
# Normalises the input using min-max scaling
inputs = (inputs-min(inputs))/float((max(inputs)-min(inputs)))
if self.n_hidden[0]>0:
# Preparing the weights and biases from the controller of layer 1
# Biases for the n hidden neurons
bias1 = controller[:self.n_hidden[0]].reshape(1,self.n_hidden[0])
# Weights for the connections from the inputs to the hidden nodes
weights1_slice = len(inputs)*self.n_hidden[0] + self.n_hidden[0]
weights1 = controller[self.n_hidden[0]:weights1_slice].reshape((len(inputs),self.n_hidden[0]))
# Outputs activation first layer.
output1 = sigmoid_activation(inputs.dot(weights1) + bias1)
# Preparing the weights and biases from the controller of layer 2
bias2 = controller[weights1_slice:weights1_slice + 5].reshape(1,5)
weights2 = controller[weights1_slice + 5:].reshape((self.n_hidden[0],5))
# Outputting activated second layer. Each entry in the output is an action
output = sigmoid_activation(output1.dot(weights2)+ bias2)[0]
else:
bias = controller[:5].reshape(1, 5)
weights = controller[5:].reshape((len(inputs), 5))
output = sigmoid_activation(inputs.dot(weights) + bias)[0]
# takes decisions about sprite actions
if output[0] > 0.5:
left = 1
else:
left = 0
if output[1] > 0.5:
right = 1
else:
right = 0
if output[2] > 0.5:
jump = 1
else:
jump = 0
if output[3] > 0.5:
shoot = 1
else:
shoot = 0
if output[4] > 0.5:
release = 1
else:
release = 0
return [left, right, jump, shoot, release]
# implements controller structure for enemy
class enemy_controller(Controller):
def __init__(self, _n_hidden):
# Number of hidden neurons
self.n_hidden = [_n_hidden]
def control(self, inputs,controller):
# Normalises the input using min-max scaling
inputs = (inputs-min(inputs))/float((max(inputs)-min(inputs)))
if self.n_hidden[0]>0:
# Preparing the weights and biases from the controller of layer 1
# Biases for the n hidden neurons
bias1 = controller[:self.n_hidden[0]].reshape(1,self.n_hidden[0])
# Weights for the connections from the inputs to the hidden nodes
weights1_slice = len(inputs)*self.n_hidden[0] + self.n_hidden[0]
weights1 = controller[self.n_hidden[0]:weights1_slice].reshape((len(inputs),self.n_hidden[0]))
# Outputs activation first layer.
output1 = sigmoid_activation(inputs.dot(weights1) + bias1)
# Preparing the weights and biases from the controller of layer 2
bias2 = controller[weights1_slice:weights1_slice + 5].reshape(1,5)
weights2 = controller[weights1_slice + 5:].reshape((self.n_hidden[0],5))
# Outputting activated second layer. Each entry in the output is an action
output = sigmoid_activation(output1.dot(weights2)+ bias2)[0]
else:
bias = controller[:5].reshape(1, 5)
weights = controller[5:].reshape((len(inputs), 5))
output = sigmoid_activation(inputs.dot(weights) + bias)[0]
# takes decisions about sprite actions
if output[0] > 0.5:
attack1 = 1
else:
attack1 = 0
if output[1] > 0.5:
attack2 = 1
else:
attack2 = 0
if output[2] > 0.5:
attack3 = 1
else:
attack3 = 0
if output[3] > 0.5:
attack4 = 1
else:
attack4 = 0
return [attack1, attack2, attack3, attack4]