Author | mihaild |
Submission date | 2016-02-08 18:16:58.411759 |
Rating | 6452 |
Matches played | 388 |
Win rate | 62.11 |
Use rpsrunner.py to play unranked matches on your computer.
from collections import defaultdict
import random
SYMBOLS = 'RPS'
class UnboundedNGramPredictor:
def __init__(self, alpha=0.5):
self.alpha = alpha
self.log = defaultdict(float)
for c in SYMBOLS:
self.log[c] += 1
def prob(self, c, history):
if not history:
return float(self.log[c]) / sum(self.log[s] for s in SYMBOLS)
d = sum(self.log[history + s] for s in SYMBOLS)
if d > 0.1:
pred_c = float(self.log[history + c]) / d
pred_p = self.prob(c, history[1:])
return pred_c * (1.0 - self.alpha) + pred_p * self.alpha
return self.prob(c, history[1:])
def add_history(self, history):
for i in range(1, len(history) + 1):
self.log[history[-i:]] += 1
if not input:
predictor = UnboundedNGramPredictor()
history = ''
history_my = ''
output = 'P'
random.seed(123)
last_loses = 0
d = {'R': 'P', 'P': 'S', 'S': 'R'}
translations = {'R': 'P', 'P': 'S', 'S': 'R'}
else:
if history:
if d[history[-1]] == history_my[-1]:
last_loses -= 0.5
elif d[history_my[-1]] == history[-1]:
last_loses += 1
if last_loses >= 10:
translations_next = {}
for c in translations:
translations_next[c] = d[translations[c]]
translations = translations_next
history += input
history = history[-10:]
predictor.add_history(history)
r = random.random()
for c in SYMBOLS:
p = predictor.prob(c, history)
if p > r:
output = translations[c]
history_my += output
break
r -= p