out_dir: results
metric_best: accuracy-SBM
wandb:
  use: True
  project: CLUSTER
dataset:
  format: PyG-GNNBenchmarkDataset
  name: CLUSTER
  task: graph
  task_type: classification
  transductive: False
  split_mode: standard
  node_encoder: True
  node_encoder_name: LinearNode+CAPE+EquivStableLapPE
  node_encoder_bn: False
  edge_encoder: True
  edge_encoder_name: DummyEdge
  edge_encoder_bn: False
posenc_EquivStableLapPE:
  enable: True
  eigen:
    laplacian_norm: none
    eigvec_norm: L2
    max_freqs: 10
  raw_norm_type: none
  dim_pe: 0
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: 24
  dim_pe: 32
  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'
  gap_eps: 5e-2
train:
  mode: custom
  batch_size: 16
  eval_period: 1
  ckpt_period: 100
  ensemble_repeat: 1
  ensemble_mode: none
model:
  type: GPSModel
  loss_fun: weighted_cross_entropy
  edge_decoding: dot
gt:  # Hyperparameters optimized for ~500k budget.
  layer_type: CustomGatedGCN+Transformer
  layers: 16
  n_heads: 8
  dim_hidden: 64  # `gt.dim_hidden` must match `gnn.dim_inner`
  dropout: 0.1
  attn_dropout: 0.5
  layer_norm: False
  batch_norm: True
gnn:
  head: inductive_node
  layers_pre_mp: 0
  layers_post_mp: 3
  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: 0.0
#  base_lr: 0.0005
#  max_epoch: 1000
#  scheduler: reduce_on_plateau
#  reduce_factor: 0.5
#  schedule_patience: 10
#  min_lr: 1e-5
optim:
  clip_grad_norm: True
  optimizer: adamW
  weight_decay: 1e-5
  base_lr: 0.0005
  max_epoch: 100
  scheduler: cosine_with_warmup
  num_warmup_epochs: 5
