Author | sdfsdf |
Submission date | 2013-04-23 12:50:43.188783 |
Rating | 7524 |
Matches played | 702 |
Win rate | 75.64 |
Use rpsrunner.py to play unranked matches on your computer.
#No lot of comment anymore
#no reverse + no draw
#credit dllu part of this AI come from him
import random
num_predictors =18
num_meta= 12
if input =="":
len_rfind = [20]
limit = [10,20,60]
beat = { "P":"S" , "R":"P" , "S":"R" }
not_lose = { "R":"PR", "P":"SP", "S":"RS" }
your_his =""
my_his = ""
both_his=""
both_his2=""
length =0
score1=[3]*num_predictors
score2=[3]*num_predictors
score3=[3]*num_predictors
score4=[3]*num_predictors
metascore=[3]*num_meta
score_meta=[0]*num_meta
temp1 = { "PP":"1","PR":"2","PS":"3",
"RP":"4","RR":"5","RS":"6",
"SP":"7","SR":"8","SS":"9"}
temp2 = { "1":"PP","2":"PR","3":"PS",
"4":"RP","5":"RR","6":"RS",
"7":"SP","8":"SR","9":"SS"}
who_win = { "PP": 0, "PR":1 , "PS":-1,
"RP": -1,"RR":0, "RS":1,
"SP": 1, "SR":-1, "SS":0}
index = { "P":0, "R":1, "S":2 }
list_meta = [""]*num_meta
output = random.choice("RPS")
predictors = [output]*num_predictors
metapredictors = [output]*num_meta
else:
#calculate score
for i in range(num_predictors):
#meta 1
score1[i]*=0.8
if input==predictors[i]:
score1[i]+=3
else:
#elif input==beat[beat[predictors[i]]]:
score1[i]-=3
#meta 2
if input==predictors[i]:
score2[i]+=3
else:
#elif input==beat[beat[predictors[i]]]:
score2[i]=0
#meta 3
score3[i]*=0.8
if output==predictors[i]:
score3[i]+=3
else:
#elif output==beat[beat[predictors[i]]]:
score3[i]-=3
#meta 4
if output==predictors[i]:
score4[i]+=3
else:
#elif output==beat[beat[predictors[i]]]:
score4[i]=0
#calculate metascore
"""
for i in range(num_meta):
metascore[i]*=0.9
if input==metapredictors[i]:
metascore[i]+=3
else:
metascore[i]=0
"""
if len(list_meta[0])<4:
front =0
else:
front =1
for i in range (num_meta):
if metapredictors[i]==input:
result ="1"
elif beat[beat[metapredictors[i]]]==input:
result ="0"
else:
result="0"
list_meta[i] = list_meta[i][front:4]+result #only 4 rounds before
#Predictors
#if length>1:
# output=beat[predict]
your_his+=input
my_his+=output
both_his+=temp1[(input+output)]
both_his2+=temp1[(output+input)]
length+=1
#history matching
for i in range(1):
len_size = min(length,len_rfind[i])
j=len_size
#both_his
while j>=1 and not both_his[length-j:length] in both_his[0:length-1]:
j-=1
if j>=1:
k = both_his.rfind(both_his[length-j:length],0,length-1)
predictors[0+6*i] = your_his[j+k]
predictors[1+6*i] = beat[my_his[j+k]]
else:
predictors[0+6*i] = random.choice("RPS")
predictors[1+6*i] = random.choice("RPS")
j=len_size
#your_his
while j>=1 and not your_his[length-j:length] in your_his[0:length-1]:
j-=1
if j>=1:
k = your_his.rfind(your_his[length-j:length],0,length-1)
predictors[2+6*i] = your_his[j+k]
predictors[3+6*i] = beat[my_his[j+k]]
else:
predictors[2+6*i] = random.choice("RPS")
predictors[3+6*i] = random.choice("RPS")
j=len_size
#my_his
while j>=1 and not my_his[length-j:length] in my_his[0:length-1]:
j-=1
if j>=1:
k = my_his.rfind(my_his[length-j:length],0,length-1)
predictors[4+6*i] = your_his[j+k]
predictors[5+6*i] = beat[my_his[j+k]]
else:
predictors[4+6*i] = random.choice("RPS")
predictors[5+6*i] = random.choice("RPS")
#Reverse
for i in range(0):
temp =""
search = temp1[(output+input)] #last round
for start in range(2, min(limit[i],length) ):
if search == both_his2[length-start]:
temp+=both_his2[length-start+1]
if(temp==""):
predictors[6+i] = random.choice("RPS")
else:
collectR = {"P":0,"R":0,"S":0} #take win/lose from opponent into account
for sdf in temp:
next_move = temp2[sdf]
if(who_win[next_move]==-1):
collectR[temp2[sdf][1]]+=3
elif(who_win[next_move]==0):
collectR[temp2[sdf][1]]+=1
elif(who_win[next_move]==1):
collectR[beat[temp2[sdf][0]]]+=1
max1 = -1
p1 =""
for key in collectR:
if(collectR[key]>max1):
max1 = collectR[key]
p1 += key
predictors[6+i] = random.choice(p1)
for i in range(6,18):
predictors[i]=beat[beat[predictors[i-6]]]
#find prediction for each meta
metapredictors[0]=predictors[score1.index(max(score1))]
metapredictors[1]=predictors[score2.index(max(score2))]
metapredictors[2]=beat[predictors[score3.index(max(score3))]]
metapredictors[3]=beat[predictors[score4.index(max(score4))]]
for i in range(4,12):
metapredictors[i] = beat[metapredictors[i-4]]
#choose meta
len_his = len(list_meta[0])
for i in range(num_meta):
sum = 0
for j in range(len_his):
if list_meta[i][j]=="1":
sum+=(j+1)*(j+1)
elif list_meta[i][j]=="0":
sum-=(j+1)*(j+1)
score_meta[i] = sum
max_score = max(score_meta)
t =""
for i in range(num_meta):
if score_meta[i]==max_score:
t+=metapredictors[i]
#predict = metapredictors[metascore.index(max(metascore))]
if max_score>0:
predict = metapredictors[score_meta.index(max_score)]
predict = random.choice(t)
else:
predict = random.choice("RPS")
output = beat[predict]