forked from Wargus/stratagus
-
Notifications
You must be signed in to change notification settings - Fork 0
/
external_ai_example.py
54 lines (50 loc) · 1.79 KB
/
external_ai_example.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
import socket
import struct
import random
if __name__ == "__main__":
# Listen for incoming datagrams
localIP = "127.0.0.1"
localPort = 9292
buffersize = 1024
sock = socket.socket(family=socket.AF_INET)
sock.bind((localIP, localPort))
sock.listen(5)
while True:
print("TCP server up and listening on", localIP, localPort)
(clientsocket, address) = sock.accept()
print("connection", address)
num_state = 0
num_actions = 0
act = 0
long_size = struct.calcsize('!l')
while(True):
command = clientsocket.recv(1)
if not command:
break
print(command)
if command == b"I":
num_state = ord(clientsocket.recv(1))
num_actions = ord(clientsocket.recv(1))
state_unpack_fmt = "!" + "l" * num_state
print("setup", num_state, num_actions)
elif command == b"R":
r = b""
while len(r) < long_size:
r += clientsocket.recv(long_size - len(r))
reward = struct.unpack("!l", r)[0]
print("reward", reward)
elif command == b"S":
r = b""
expected = long_size * num_state
while len(r) < expected:
r += clientsocket.recv(expected - len(r))
args = struct.unpack(state_unpack_fmt, r)
print("step", args)
# act = random.choice(range(num_actions))
act = act % num_actions
print("action", act)
clientsocket.sendall(bytearray([act]))
act += 1
elif command == b"E":
e = ord(clientsocket.recv(1))
print("end", e)