-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathusi.py
executable file
·91 lines (80 loc) · 2.95 KB
/
usi.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
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import argparse
import sys
import chainer
import chainer.functions as F
import numpy as np
import net
from shogi import Shogi
def main():
parser = argparse.ArgumentParser(description='CNN Shogi USI Interface:')
parser.add_argument('--npz', '-n', default='result/snapshot',
help='Snapshot')
parser.add_argument('--gpu', '-g', type=int, default=-1,
help='GPU ID (negative value indicates CPU)')
args = parser.parse_args()
xp = chainer.cuda.cupy if args.gpu >= 0 else np
while True:
try:
if sys.version_info[0] == 2:
command = raw_input()
else:
command = input()
except EOFError:
continue
command = command.split()
if command[0] == 'usi':
print('id name CNN Shogi')
print('id author not')
print('usiok')
elif command[0] == 'isready':
model = net.Model()
chainer.serializers.load_npz(args.npz, model)
print('readyok')
elif command[0] == 'position':
shogi = Shogi()
for move in command[1:]:
if move == 'startpos' or move == 'moves':
continue
shogi.move(move)
elif command[0] == 'go':
res = model(np.asarray([shogi.get_channels()]))
res = F.argmax(res)
res = res.data
channel = res / 81
to_y = res % 81 / 9
to_x = res % 9
if shogi.turn == 1:
shogi.board = xp.flipud(shogi.board)
shogi.board = xp.fliplr(shogi.board)
if channel < 20:
dy = [0, 0, 1, -1, 1, -1, 1, -1, 2, 2]
dx = [1, -1, 0, 0, 1, -1, -1, 1, 1, -1]
try:
for i in range(1, 9):
from_y = to_y + i * dy[channel % 10]
from_x = to_x + i * dx[channel % 10]
if shogi.board[from_y][from_x] != 0:
break
except IndexError:
print('bestmove resign')
if shogi.turn == 1:
to_y = 8 - to_y
to_x = 8 - to_x
from_y = 8 - from_y
from_x = 8 - from_x
print('bestmove ' + chr(ord('9')-from_x) + chr(ord('a')+from_y)
+ chr(ord('9')-to_x) + chr(ord('a')+to_y) + ('' if channel < 10 else '+'))
else:
if shogi.turn == 1:
to_y = 8 - to_y
to_x = 8 - to_x
piece = ['P', 'L', 'N', 'S', 'G', 'B', 'R']
print('bestmove ' + piece[channel-20] + '*'
+ chr(ord('9')-to_x) + chr(ord('a')+to_y))
elif command[0] == 'quit':
break
sys.stdout.flush()
if __name__ == '__main__':
main()