trainer:
  accelerator: auto
  devices: auto
  max_epochs: 30
  gradient_clip_val: 1
  default_root_dir: logs
  logger: false
  callbacks:
  - class_path: lightning.pytorch.callbacks.ModelCheckpoint # save ckpt at the end of each epoch, and save the best val_mcc ckpt
    init_args:
      filename: epoch_{epoch}-val_mcc:{val_mcc:.3f}
      monitor: val_mcc
      mode: max
  - class_path: lightning.pytorch.callbacks.early_stopping.EarlyStopping
    dict_kwargs:
      monitor: val_mcc
      mode: max
      patience: 30
model:
  class_path: modelgenerator.tasks.SequenceClassification
  init_args:
    backbone:
      class_path: modelgenerator.backbones.aido_dna_7b
      init_args:
        use_peft: true
    adapter: modelgenerator.adapters.LinearCLSAdapter
    n_classes: 2
    optimizer:
      class_path: torch.optim.AdamW
      init_args:
        lr: 0.0005
        weight_decay: 0.1
    lr_scheduler:
      class_path: modelgenerator.lr_schedulers.CosineWithWarmup
      init_args:
        warmup_ratio: 0.1
data:
  class_path: modelgenerator.data.NTClassification
  init_args:
    config_name: promoter_all
    train_split_name: train
    test_split_name: test
    valid_split_size: 0.1
    batch_size: 4

