-
Notifications
You must be signed in to change notification settings - Fork 43
/
tiles_beam_experiments.py
111 lines (90 loc) · 3.49 KB
/
tiles_beam_experiments.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
# Copyright 2023 The tpu_graphs Authors.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
r"""Hyperparameter search for training baseline models on tile dataset."""
from collections.abc import Sequence
import json
from absl import app
from absl import flags
import apache_beam as beam
from tpu_graphs.baselines.tiles import train_args
from tpu_graphs.baselines.tiles import train_lib
_DEBUG = flags.DEFINE_bool(
'debug', False, 'If set, only 2 jobs will be ran')
_BASE_ARGS = {
'out_dir': '~/out/tpugraphs_tiles/beam',
'test_mode': 'metrics',
'validate_batches': 50,
'eval_every': 2,
'early_stop': 10, # Stops after 10 epochs if val OPA does not improve.
'epochs': 500,
'configs': 8,
}
def get_parameter_sweep_1() -> list[train_args.TrainArgs]:
"""Hyperparameter sweep for main paper submission."""
batch_sizes = [10]
learning_rates = [1e-2, 1e-3]
clip_norms = [1e-3, 100.0]
run_ids = [0, 1, 2]
losses = ['ListMLELoss:1,MSE:0.02', 'MSE:1', 'ListMLELoss:1']
gnn_models = ('EarlyJoinSAGE', 'LateJoinSAGE', 'EarlyJoinResGCN',
'LateJoinResGCN')
gnn_args = [
{'num_gnns': 2, 'op_embed_dim': 64, 'hidden_dim': 64},
{'num_gnns': 3, 'op_embed_dim': 64, 'hidden_dim': 64},
{'num_gnns': 3, 'op_embed_dim': 128, 'hidden_dim': 128},
{'num_gnns': 3, 'op_embed_dim': 256, 'hidden_dim': 128},
]
model_and_args_list = [
# MLP
('MLP', {'op_embed_dim': 64, 'hidden_dim': 64, 'mlp_layers': 2}),
('MLP', {'op_embed_dim': 128, 'hidden_dim': 128, 'mlp_layers': 2}),
('MLP', {'op_embed_dim': 128, 'hidden_dim': 128, 'mlp_layers': 3}),
('MLP', {'op_embed_dim': 256, 'hidden_dim': 128, 'mlp_layers': 3}),
]
for gnn_model in gnn_models:
for gnn_arg in gnn_args:
model_and_args_list.append((gnn_model, gnn_arg))
all_args: list[train_args.TrainArgs] = []
for model, model_args in model_and_args_list:
for loss in losses:
for run_id in run_ids:
for clip_norm in clip_norms:
for lr in learning_rates:
for batch in batch_sizes:
args = dict(_BASE_ARGS) # copy.
args['model'] = model
args['model_kwargs_json'] = json.dumps(model_args)
args['losses'] = loss
args['clip_norm'] = clip_norm
args['learning_rate'] = lr
args['run_id'] = run_id
args['batch_size'] = batch
all_args.append(train_args.TrainArgs(**args))
return all_args
def _run_args(args: dict[str, str | float | int]):
train_lib.train(train_args.TrainArgs(**args))
def pipeline(root) -> beam.pvalue.PCollection:
train_arg_list = get_parameter_sweep_1()
if _DEBUG.value:
train_arg_list = train_arg_list[:2]
train_arg_list = [args._asdict() for args in train_arg_list]
return (
root
| beam.Create(train_arg_list)
| beam.Reshuffle()
| beam.Map(_run_args))
def main(unused_argv: Sequence[str]) -> None:
p = beam.Pipeline(); pipeline(p); p.run()
if __name__ == '__main__':
app.run(main)