# @package _global_
defaults:
  - /config  # inherit global defaults

# -------------------------------
# Core experiment configuration
# -------------------------------
modelwrapper: gpan_lora
model: meta-llama/Meta-Llama-3.1-8B
dataset_type: mcdataset
dataset: obqa   # can be extended to ： [obqa, ARC-Challenge, ARC-Easy, winogrande_m, boolq]
seed: 3
evaluate: true

# -------------------------------
# Training and optimization
# -------------------------------
lr: 1e-4
batch_size: 4
opt: adamw
warmup_ratio: 0.06
max_seq_len: 300
max_train_steps: 5000
eval_per_steps: 500
subset_size: 0.8

# -------------------------------
# LoRA options
# -------------------------------
apply_classhead_lora: true
lora_r: 8
lora_alpha: 16
lora_dropout: 0.0

# -------------------------------
# Bayesian LoRA parameters
# -------------------------------
bayes_eps: 0.5
bayes_beta: 0.15
bayes_gamma: 8 
bayes_kllr: 0.0075
bayes_kllr_std: 0.01
bayes_momentum: 0
bayes_opt2_wd: 0
bayes_kl_reweighting: 0
bayes_train_n_samples: 1
bayes_eval_n_samples: 10
bayes_eval_n_samples_final: 10
kl_scale: 1e-3


# -------------------------------
# WandB
# -------------------------------
wandb_project: WANDB_PROJECT_NAME
wandb_entity: WANDB_ENTITY_NAME

# -------------------------------
# Dynamic name composition
# -------------------------------
exp_name: >-
  RUN_NAME

# -------------------------------
# Reuse dynamically composed name
# -------------------------------
wandb_name: ${exp_name}
log_path: ${exp_name}
checkpoint_name: ${exp_name}

# -------------------------------
# Hydra output control (optional)
# -------------------------------
hydra:
  run:
    dir: ./outputs/${now:%Y-%m-%d}/${exp_name}
  sweep:
    dir: ./outputs/${now:%Y-%m-%d}
    subdir: ${exp_name}
  sweeper:
    params:
      bayes_train_n_samples: 1
      dataset: obqa #obqa, winogrande_s, ARC-Challenge, ARC-Easy, winogrande_m, boolq
      seed: 1, 2, 3
      
      