-
Notifications
You must be signed in to change notification settings - Fork 1
/
generate_experiments_self_consistency.py
73 lines (67 loc) · 2.01 KB
/
generate_experiments_self_consistency.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
root_experiments = [
{
'dataset_name': 'mnist',
'problem': 'consistency_type_1',
'used_rows': n,
'batch_size': 16,
} for n in range(28)
] + [
{
'dataset_name': 'mnist',
'problem': 'consistency_type_2',
'used_rows': n,
'batch_size': 16
} for n in range(28)
] + [
{
'dataset_name': 'mnist',
'problem': 'consistency_type_3',
'used_rows': n,
'batch_size': 32
} for n in range(28)
] + [
{
'dataset_name': 'cifar10',
'problem': 'consistency_type_1',
'used_rows': n,
'batch_size': 16,
} for n in range(32)
] + [
{
'dataset_name': 'cifar10',
'problem': 'consistency_type_2',
'used_rows': n,
'batch_size': 16,
} for n in range(32)
] + [
{
'dataset_name': 'cifar10',
'problem': 'consistency_type_3',
'used_rows': n,
'batch_size': 32
} for n in range(32)
]
experiments = []
for i in range(10):
for loss in ('iMINE', 'iMINE_j', 'SMILE', 'SMILE_JS', 'MINE', 'InfoNCE', 'JS', 'alpha'):
for e in root_experiments:
e = e.copy()
e['loss'] = loss
e['experiment_name'] = i
experiments.append(e)
gpu_ids = (0, 1, 2, 3, 4, 5, 6)
process_per_gpus = 2
experiments_per_queue = [
{'commands': [], 'gpu_id': gpu_id, 'process_id': process_id, 'compiled_command': ''}
for gpu_id in gpu_ids
for process_id in range(process_per_gpus)
]
for index, experiment in enumerate(experiments):
target_queue_index = index % len(experiments_per_queue)
gpu_id = experiments_per_queue[target_queue_index]['gpu_id']
experiments_per_queue[target_queue_index]['commands'].append(
f'CUDA_VISIBLE_DEVICES={gpu_id} python3 experiments.py ' + ' '.join(f'--{k} {v}' for k, v in experiment.items())
)
for q in experiments_per_queue:
q['compiled_command'] = '(%s)&' % '; '.join(q['commands'])
print('\n'.join([q['compiled_command'] for q in experiments_per_queue]))