-
Notifications
You must be signed in to change notification settings - Fork 64
/
Copy pathconfig.py
66 lines (53 loc) · 2.19 KB
/
config.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
from collections import namedtuple
import json
class Config(object):
"""Configuration module."""
def __init__(self, config):
self.paths = ""
# Load config file
with open(config, 'r') as config:
self.config = json.load(config)
# Extract configuration
self.extract()
def extract(self):
config = self.config
# -- Clients --
fields = ['total', 'per_round', 'label_distribution',
'do_test', 'test_partition']
defaults = (0, 0, 'uniform', False, None)
params = [config['clients'].get(field, defaults[i])
for i, field in enumerate(fields)]
self.clients = namedtuple('clients', fields)(*params)
assert self.clients.per_round <= self.clients.total
# -- Data --
fields = ['loading', 'partition', 'IID', 'bias', 'shard']
defaults = ('static', 0, True, None, None)
params = [config['data'].get(field, defaults[i])
for i, field in enumerate(fields)]
self.data = namedtuple('data', fields)(*params)
# Determine correct data loader
assert self.data.IID ^ bool(self.data.bias) ^ bool(self.data.shard)
if self.data.IID:
self.loader = 'basic'
elif self.data.bias:
self.loader = 'bias'
elif self.data.shard:
self.loader = 'shard'
# -- Federated learning --
fields = ['rounds', 'target_accuracy', 'task', 'epochs', 'batch_size']
defaults = (0, None, 'train', 0, 0)
params = [config['federated_learning'].get(field, defaults[i])
for i, field in enumerate(fields)]
self.fl = namedtuple('fl', fields)(*params)
# -- Model --
self.model = config['model']
# -- Paths --
fields = ['data', 'model', 'reports']
defaults = ('./data', './models', None)
params = [config['paths'].get(field, defaults[i])
for i, field in enumerate(fields)]
# Set specific model path
params[fields.index('model')] += '/' + self.model
self.paths = namedtuple('paths', fields)(*params)
# -- Server --
self.server = config['server']