# Original:  zinc-GRIT-2000.yaml
out_dir: results
metric_best: accuracy
tensorboard_each_run: False  # Log to Tensorboard each run
#accelerator: "cuda:3"
#device: "cuda:3"
accelerator: "cuda:0"
mlflow:
  use: False
  project: Exp
  name: TUDataset
wandb:
  use: False
  project: QM9
dataset:
  format: PyG-TUDataset
  name: IMDB-BINARY
  task: graph
  task_type: classification
  transductive: False
  node_encoder: True
  node_encoder_name: LinearNode+CAPE
#  node_encoder_num_types: 28
  node_encoder_bn: False
  edge_encoder: True
  edge_encoder_name: DummyEdge
  edge_encoder_bn: False
  split_mode: cv-kfold-10
posenc_CAPE:
  enable: True
  type: onespace
  decouple: True
  use_signnet: False  # override other settings to use SignNet; always set to False, otherwise use posenc_SignNet
  use_laplacian: True
  normalize_matrix: False
  dim_h: 32
  dim_pe: 16
  layers: 3
  gp_layer: 'ew'
  set2set_layers: 2
  max_mult: 4
  eigen_noise: 1e-5
  use_eigenvalue: False # use eigenvalue information in Clifford NN
  use_concat: False # concatenate invariant representations of different eigenspaces for each graph, instead of pooling
  dim_reduction_method: 'learnable_project'
  eigvec_lim: 8
  restrict_grade: None
  share_weights: False
  lambda_norm: 'none'
train:
  mode: custom
  batch_size: 32
  eval_period: 1
  enable_ckpt: True  # Checkpointing can now be disabled to save I/O when e.g. just benchmarking.
  ckpt_best: True  # WARNING: Checkpoint every epoch a better model is found may increase I/O significantly.
  ckpt_period: 100
  ensemble_repeat: 1
  ensemble_mode: none
model:
  type: GPSModel
  loss_fun: cross_entropy
  edge_decoding: dot
  graph_pooling: add
gt:
  layer_type: GINE+None
  layers: 10
  n_heads: 8
  dim_hidden: 64  # `gt.dim_hidden` must match `gnn.dim_inner`
  dropout: 0.0
  attn_dropout: 0.5
  layer_norm: False
  batch_norm: True
gnn: # decoder --> san_graph = MLP + pooling
  head: san_graph
  layers_pre_mp: 0
  layers_post_mp: 3  # Not used when `gnn.head: san_graph`
  dim_inner: 64  # `gt.dim_hidden` must match `gnn.dim_inner`
  batchnorm: True
  act: relu
  dropout: 0.0
  agg: mean
  normalize_adj: False
optim:
  clip_grad_norm: True
  optimizer: adamW
  weight_decay: 1e-4
  base_lr: 1e-3
  max_epoch: 1000
  num_warmup_epochs: 50
  scheduler: cosine_with_warmup
  min_lr: 1e-6
