defaults:
  - _self_
  - logger: neptune-offline
  - dataset: bench-hard
  - architecture: classification
  - pooler: mincut
  - optimizer: adam
  - profiler: none
  - lr_scheduler: none

#### Log and sweep params 
hydra:
  run:
    dir: logs/${dataset.name}/${architecture.name}/${pooler.name}/${now:%Y-%m-%d}/${now:%H-%M-%S}
  sweep:
    dir: logs/${now:%Y-%m-%d-%H-%M-%S}
    subdir: ${dataset.name}/${architecture.name}/${pooler.name}/${hydra.job.num}
  callbacks:
    cuda_cleanup:
      _target_: source.utils.misc.CUDACleanupCallback

#### Experiment params 
tags: ${cat:${default_tags},${run_tags}}
timeout: null

default_tags:
  - ${architecture.name}
  - ${pooler.name}
  - ${dataset.name}

run_tags: []

workers: 16
log_grad_norm: False
log_lr: True

plot_preds_at_epoch:
  set: ['train']
  batch: 0
  samples: 0
  every: 50
  types: ["pooled_graph", "assignments", "s_matrix", "sts", "sst"]

#### Training params
epochs: 10000
limit_train_batches: null
limit_val_batches: null
clip_val: 5.0  # Gradient clipping value

callbacks:
  early_stop: True
  patience: 300
  checkpoints: True   # save checkpoints while training
  monitor: val_loss
  mode: min
  timer: False # Monitor train/validation time