# lightning.pytorch==2.4.0
seed_everything: 42
trainer:
  accelerator: auto
  strategy:
    class_path: lightning.pytorch.strategies.DDPStrategy
  devices: auto
  num_nodes: 1
  precision: 32
  logger:
    class_path: lightning.pytorch.loggers.WandbLogger
    init_args:
      name: ssp_AIDO.Protein_16B
      save_dir: logs
      project: xtrimo_benchmark
  callbacks:
  - class_path: lightning.pytorch.callbacks.ModelCheckpoint
    init_args:
      dirpath: logs/xtrimo_benchmark/ssp_AIDO.Protein_16B
      filename: best_val:{epoch}-{val_accuracy:.3f}
      monitor: val_accuracy
      save_top_k: 1
      mode: max
      every_n_epochs: 1
  max_epochs: 15
  max_steps: -1
  log_every_n_steps: 50
  accumulate_grad_batches: 1
  gradient_clip_val: 0.01
  default_root_dir: null
model:
  class_path: modelgenerator.tasks.TokenClassification
  init_args:
    adapter:
      class_path: modelgenerator.adapters.MLPAdapter
      init_args:
        hidden_sizes:
        - 128
        bias: true
        dropout: 0.1
        dropout_in_middle: true
    backbone:
      class_path: modelgenerator.backbones.aido_protein_16b
      init_args:
        max_length: 512
        use_peft: true
        save_peft_only: true
        lora_r: 16
        lora_alpha: 16
        lora_dropout: 0.0
        lora_target_modules:
        - query
        - value
        - key
        - dense
        - router
        lora_use_rslora: true
        config_overwrites:
          hidden_dropout_prob: 0
          attention_probs_dropout_prob: 0
        model_init_args: null
    n_classes: 3
    optimizer:
      class_path: torch.optim.AdamW
      init_args:
        lr: 0.0001
        betas:
        - 0.9
        - 0.95
        eps: 1.0e-08
        weight_decay: 0.0
    lr_scheduler:
      class_path: modelgenerator.lr_schedulers.CosineWithWarmup
      init_args:
        warmup_ratio: 0.05
    strict_loading: true
    reset_optimizer_states: false
data:
  class_path: modelgenerator.data.SspQ3
  init_args:
    path: proteinglm/ssp_q3
    batch_size: 1
    max_length: 512
    train_split_name: train
    test_split_name: test
    valid_split_size: 0.1
    random_seed: 42
    shuffle: true
ckpt_path: null