-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathshapley.py
130 lines (110 loc) · 4.05 KB
/
shapley.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
125
126
127
128
129
130
import itertools
from itertools import combinations
from itertools import permutations
def power_set(List):
"""
function to return the powerset of a list
"""
subs = [list(j) for i in range(len(List)) for j in combinations(List, i+1)]
return subs
def characteristic_function_check(player_list,characteristic_function):
"""
A function to check if a characteristic_function is valid
"""
r=True
player_power_set=power_set(player_list)
for e in player_power_set:
if ",".join(e) not in characteristic_function:
print "ERROR: characteristic_function domain does not match players."
return False
for e in player_power_set:
e=",".join(e)
for b in player_power_set:
b=",".join(b)
if e in b:
if characteristic_function[e]>characteristic_function[b]:
print "ERROR: game is not Monotone"
return False
return r
def predecessors(player,player_permutation):
"""
A function to return the predecessors of a player
"""
r=[]
for e in player_permutation:
if e!=player:
r.append(e)
else:
break
return r
def Marginal_Contribution(player,player_permutation,characteristic_function):
"""
A function to return the marginal contribution of a player for a given permutation
"""
pred=predecessors(player,player_permutation)
predecessor_contribution=0
for e in permutations(pred):
e=",".join(e)
if e in characteristic_function:
predecessor_contribution=characteristic_function[e]
pred.append(player)
for e in permutations(pred):
e=",".join(e)
if e in characteristic_function:
return characteristic_function[e]-predecessor_contribution
def Shapley_calculation(player_list,characteristic_function):
"""
A function to return the shapley value of a game
"""
Marginal_Contribution_dict={}
for e in player_list:
Marginal_Contribution_dict[e]=0
k=0
for pi in permutations(player_list):
k+=1
for e in player_list:
Marginal_Contribution_dict[e]+=Marginal_Contribution(e,pi,characteristic_function)
for e in Marginal_Contribution_dict:
Marginal_Contribution_dict[e]/=k
return Marginal_Contribution_dict
class Coop_Game():
def __init__(self,player_list,characteristic_function):
self.player_list=player_list
self.valid=False
if type(characteristic_function) is dict:
if characteristic_function_check(self.player_list,characteristic_function):
self.characteristic_function=characteristic_function
self.valid=True
else:
print ""
print "Characteristic function is not valid."
print ""
else:
print ""
print "The characteristic function must be a dictionary."
print ""
def shapley(self):
self.shapley=Shapley_calculation(self.player_list,self.characteristic_function)
return self.shapley
#def _(nbr_of_players=("Number of Players",3)):
if __name__ == "__main__":
print "hello world"
nbr_of_players=3
player_list=["%s"%e for e in range(1,nbr_of_players+1)]
print player_list
coalition_list=power_set(player_list)
m=len(coalition_list)
characteristic_function_list=[]
for e in coalition_list[:-1]:
characteristic_function_list.append([e,0])
characteristic_function_list.append([coalition_list[-1],1])
cf = [(['1'],0), (['2'],0), (['3'],0) , (['1','2'],300), (['1','3'],300), (['2','3'],0), (['1','2','3'],300)]
characteristic_function=dict([[",".join(e[0]),e[1]] for e in cf])
if characteristic_function_check(player_list,characteristic_function):
a=Coop_Game(player_list,characteristic_function)
print "The shapley value is given by the following dictionary:"
print a.shapley()
def interact():
print "hello world"
#if __name__ == "__main__":
# print "hello world"