-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathutils.py
164 lines (129 loc) · 5.52 KB
/
utils.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
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
import numpy as np
import itertools
import os
import json
import networkx as nx
# import dimod
# from dwave.system.samplers import DWaveSampler
# from dwave.system.composites import EmbeddingComposite
import numpy as np
#Different distributions data generator functions
def normal(size=1, mu=0, sigma=50, low=-100, high=100):
values = np.random.normal(mu, sigma, size)
values = np.interp(values, (values.min(), values.max()), (low, high))
return values
def uniform(size=1, low=-100, high=100):
values = np.random.normal(low, high, size)
values = np.interp(values, (values.min(), values.max()), (low, high))
return values
def laplace(size=1, loc=0, scale=50, low=-100, high=100):
values = np.random.laplace(loc, scale, size)
values = np.interp(values, (values.min(), values.max()), (low, high))
return values
def beta(size=1, a_beta=1 , b_beta=1, low=-100, high=100):
values = np.random.beta(a_beta, b_beta, size)
values = np.interp(values, (values.min(), values.max()), (low, high))
return values
def binomial(size=1, n_trails=1000000, p_trails=0.5, low=-100, high=100):
values = np.random.binomial(n_trails, p_trails, size)
values = np.interp(values, (values.min(), values.max()), (low, high))
return values
def chisquare(size=1, degree_of_freedom=2, low=-100, high=100):
values = np.random.chisquare(degree_of_freedom,size)
values = np.interp(values, (values.min(), values.max()), (low, high))
return values
def exponential(size=1, scale=1.0, low=-100, high=100):
values = np.random.exponential(scale, size)
values = np.interp(values, (values.min(), values.max()), (low, high))
return values
def gamma(size=1, shape=1.0, scale=1.0, low=-100, high=100):
values = np.random.gamma(shape, scale, size)
values = np.interp(values, (values.min(), values.max()), (low, high))
return values
def geometric(size=1, p=0.001, low=-100, high=100):
values = np.random.geometric(p, size)
values = np.interp(values, (values.min(), values.max()), (low, high))
return values
def rayleigh(size=1, scale=1.0, low=-100, high=100):
values = np.random.rayleigh(scale, size)
values = np.interp(values, (values.min(), values.max()), (low, high))
return values
def random(size=1, low=-100, high=100):
values = np.random.random_sample(size)
values = np.interp(values, (values.min(), values.max()), (low, high))
return values
def weibull(size=1, a=1.0, low=-100, high=100):
values = np.random.weibull(a, size)
values = np.interp(values, (values.min(), values.max()), (low, high))
return values
def f_distribution(size=1, dfnum=1, dfden=100, low=-100, high=100):
values = np.random.f(dfnum, dfden, size)
values = np.interp(values, (values.min(), values.max()), (low, high))
return values
# Generate induced subgraph game
def generate_induced_subgraph_game(distribution, n_agents, **kwargs):
induced_subgraph_game = {}
keys = list(itertools.combinations(range(1,n_agents+1), 2))
totalinteractions = len(keys)
values = distribution(totalinteractions, **kwargs)
for i,key in enumerate(keys):
induced_subgraph_game[','.join(map(str,key))] = round(values[i],2)
return induced_subgraph_game
# Convert induced subgraph game to a generic coalitional game
def induced_subgraph_game_to_coalition_game(n_agents, induced_subgraph_game):
coalition_game = {}
totalcoalitions = 2 ** n_agents
agents = list(map(str,(range(1, n_agents + 1))))
for agent in agents:
coalition_game[agent] = 0
for key,value in induced_subgraph_game.items():
coalition_game[key] = value
for coalition_size in range(3,n_agents+1):
coalitions = list(itertools.combinations(agents, coalition_size))
for coalition in coalitions:
value = []
for key in induced_subgraph_game:
if key.split(",")[0] in coalition and key.split(",")[1] in coalition:
value.append(induced_subgraph_game[key])
coalition_game[','.join(coalition)] = sum(value)
return coalition_game
# Convert generic coalitional game to induced subgraph game
def coalition_game_to_induced_subgraph_game(n_agents, coalition_game):
induced_subgraph_game = {}
for coalition in coalition_game:
if len(coalition.split(","))==2:
induced_subgraph_game[coalition] = coalition_game[coalition]
return induced_subgraph_game
#For converting the coalition game dictionary to the benchmark dataset schema
def coalition_game_to_dataset_format(n_agents, coalition_game):
c_values = []
c_values.append(0)
for i in range(1,len(coalition_game)+1):
coalition_binary_str = bin(i)[2:].zfill(n_agents)[::-1]
agents = sorted([idx+1 for idx, b in enumerate(coalition_binary_str) if int(b)])
agents = ','.join(map(str,agents))
c_values.append(coalition_game[agents])
return c_values
# For converting the benchmark dataset schema to coalition game dictionary
def dataset_format_to_coalition_game(n_agents, c_values):
coalition_game = {}
for index,c_value in enumerate(c_values[1:]):
index_binary = bin(index+1)[2:].zfill(n_agents)[::-1]
key = []
for agent,digit in enumerate(index_binary):
if int(digit):
key.append(agent+1)
key = ','.join(map(str,sorted(key)))
coalition_game[key] = c_value
return coalition_game
def save_json(filename, dictionary):
with open(filename + '.json', 'w') as fp:
json.dump(dictionary, fp)
def create_dir(path, log=False):
if not os.path.exists(path):
if log:
print('The directory', path, 'does not exist and will be created')
os.makedirs(path)
else:
if log:
print('The directory', path, ' already exists')