---
out_dir: results
dim_out: 1
metric_best: mae
num_workers: 4
wandb:
  use: True
  name: test
  project: copt-maxclique-imdb
  entity: guy-wolf
dataset:
  format: PyG-TUDataset
  name: IMDB-BINARY
  task: graph
  # task_type: classification
  split_mode: cv-kfold-5
  split_dir: splits
  node_encoder: true
  node_encoder_name: GraphStats
  node_encoder_bn: false
  graph_stats: ['degree', 'eccentricity', 'cluster_coefficient', 'triangle_count']
  multiprocessing: false
  label: false
posenc_LapPE:
  enable: false
  eigen:
    laplacian_norm: none
    eigvec_norm: L2
    max_freqs: 4
    skip_zero_freq: true
    eigvec_abs: true
  model: DeepSet
  dim_pe: 32
  layers: 2
  n_heads: 4  # Only used when `posenc.model: Transformer`
  raw_norm_type: none
posenc_RWSE:
  enable: true
  kernel:
    times_func: range(2,22)  # if no self-loop, then RWSE1 will be all zeros
  model: Linear
  dim_pe: 32
  raw_norm_type: BatchNorm
posenc_GraphStats:
  enable: false
  model: Linear
  dim_pe: 16
  raw_norm_type: none
posenc_NormalRE:
  enable: false
  dim_pe: 16
train:
  mode: copt
  # compile: True
  task: maxclique
  batch_size: 256
  eval_period: 1
  ckpt_period: 100
  ckpt_best: true
model:
  type: gnn
  loss_fun: maxclique_loss
  edge_decoding: dot
  graph_pooling: mean
gnn:
  head: copt_inductive_node
  layers_pre_mp: 1
  layers_mp: 2
  layers_post_mp: 2
  dim_inner: 32
  layer_type: hybridconv
  stage_type: skipsum_concat
  batchnorm: true
  act: linear
  last_act: null
  last_norm: minmax
  dropout: 0.0
  agg: mean
  normalize_adj: false
  hybrid:
    combine_fn: 'att'
  hybrid_v2:
    skip: false
optim:
  base_lr: 0.001
  max_epoch: 20
  optimizer: adamW
  weight_decay: 0.0
  scheduler: cosine_with_warmup
  num_warmup_epochs: 5
maxclique_loss:
  beta: 0.1
metrics:
  maxclique:
    dec_length: 300
    num_seeds: 10