# @package _global_
defaults:
  - override /model: trellis_cond_mlp_cgfm.yaml
  - override /datamodule: trellis_dataloader.yaml 
  - override /logger:
      - csv
      - wandb
  - override /trainer: gpu

hydra:
  launcher:
    name: "cgfm_trellis"

seed: 0

datamodule:
  batch_size: 1
  ivp_batch_size: 1024
  split: patients
  plot_pca: False
  num_components: null
  use_small_exp_num: False
  seed: 0

model:
  name: cgfm_trellis
  lr: 1e-4
  dim: 43
  num_hidden: 512
  num_layers: 7 
  base: source 
  num_exp_conditions: 927
  num_treat_conditions: 11
  pca_space_eval: True # only used of num_components is not null
  run_validation: True
  integrate_time_steps: 500 
  seed: 0

trainer:
  max_epochs: 750
  min_epochs: 750
  check_val_every_n_epoch: 750
  accelerator: gpu
  devices: 1
  #log_every_n_steps: 500

checkpoint:
  filename: "chkpt"

# NOTE: early stopping is NOT being used
callbacks:
  model_checkpoint:
    monitor: "val/2-Wasserstein-PDO"
    save_top_k: 1
    save_last: True

  early_stopping:
    monitor: "val/2-Wasserstein-PDO"
    mode: "min" 
    patience: 100 
    min_delta: 0 

logger:
  wandb:
    tags: ["trellis", "cgfm"]