# 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: ta_ecoli_aido_rna_1b600m_fold0
      save_dir: logs
      project: rna_tasks
  callbacks:
  - class_path: lightning.pytorch.callbacks.ModelCheckpoint
    init_args:
      dirpath: logs/rna_tasks/ta_ecoli_aido_rna_1b600m_fold0
      filename: best_val:{epoch}-{val_pearson:.3f}
      monitor: val_pearson
      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: 1
  default_root_dir: logs
model:
  class_path: modelgenerator.tasks.SequenceRegression
  init_args:
    backbone:
      class_path: modelgenerator.backbones.aido_rna_1b600m
      init_args:
        max_length: 1024
        use_peft: true
        save_peft_only: true
        lora_r: 32
        lora_alpha: 64
        lora_dropout: 0.1
        lora_target_modules:
        - query
        - value
        config_overwrites:
          hidden_dropout_prob: 0.1
          attention_probs_dropout_prob: 0.1
        model_init_args: null
    adapter:
      class_path: modelgenerator.adapters.MLPPoolAdapter
      init_args:
        pooling: mean_pooling
        hidden_sizes:
        - 512
        bias: true
        dropout: 0.1
        dropout_in_middle: false
    num_outputs: 1
    optimizer:
      class_path: torch.optim.AdamW
      init_args:
        lr: 0.0003
        betas:
        - 0.9
        - 0.999
        eps: 1.0e-08
        weight_decay: 0.01
    lr_scheduler:
      class_path: modelgenerator.lr_schedulers.CosineWithWarmup
      init_args:
        warmup_ratio: 0.01
    strict_loading: true
    reset_optimizer_states: false
data:
  class_path: modelgenerator.data.TranscriptAbundance
  init_args:
    path: genbio-ai/rna-downstream-tasks
    config_name: transcript_abundance_ecoli
    normalize: true
    train_split_name: train
    random_seed: 42
    batch_size: 4     # global_batch_size = 16
    shuffle: true
    cv_num_folds: 5
    cv_test_fold_id: 0
    cv_enable_val_fold: true
    cv_fold_id_col: fold_id
ckpt_path: null
