# @package _global_

# python finetune.py exps=noisy_dna/noisyDNA_TEST_SC

defaults:
  - override /general: scratch # or resume
  - override /model: gpt
  - override /train: base
  - override /finetune: finetune_noisy_dna_SC

hydra:
  run:
    dir: ../model_checkpoints/${project}/${general.run_dir}

project: TRACE_RECONSTRUCTION
experiment: pretraining_test # pretraining experiment for model loading

general:
  now_str: ${now:%Y%m%d_%H%M%S}
  train_time: '20241127_175939' # pretraining time if finetuning from scratch, finetuning time if resuming
  #train_time: '20241127_181841'
  run_dir: ${finetune.finetune_data_type}_${finetune.finetune_sequence_type}_${finetune.finetune_target_type}_observation_size_${finetune.finetune_observation_size}_ground_truth_${finetune.finetune_ground_truth_length}/${finetune.finetune_experiment}/train_run_${model.model_type}_${general.now_str}/

data:
  data_type: ids_data
  sequence_type: nuc
  observation_size: 5 
  target_type: CPRED 
  ground_truth_length: 60
  lower_bound_obs_size: 2
  block_size: 600

train:
  ddp: ~
  eval_interval: 250
  log_interval: 10
  eval_iters: 250
  eval_only: false
  always_interval: 500
  always_save_checkpoint: true
  device: cuda:0
  gradient_accumulation_steps: 2
  batch_size: 8
  learning_rate: 0.0001
  max_iters: 200000
  weight_decay: 0.1
  beta1: 0.9
  beta2: 0.95
  grad_clip: 1.0
  decay_lr: true
  warmup_iters: 500
  min_lr: 0.0
  lr_decay_iters: ${train.max_iters} 

model:
  gpt_params:
    n_layer: 2
    n_head: 2
    n_embd: 64
    dropout: 0.2
    bias: false

wandb: 
  wandb_log: true