exp_dir:
checkpoint:
  # [Checkpoint Loading Priority]
  # 1. If 'pretrained_model' is provided, load directly from: {exp_dir}/{pretrained_model}
  # 2. Else if 'iter' > 0, load from: {exp_dir}/averaged_iter{iter}_avg{avg}.pt if exists else do model averaging from checkpoint-xxx.pt
  # 3. Else if 'epoch' > 0, load from: {exp_dir}/averaged_epoch{epoch}_avg{avg}.pt if exists else do model averaging from epoch-xxx.pt
  # 4. If nothing is given, load from: {exp_dir}/pretrained.pt
  pretrained_model:         # e.g., "pretrained.pt"
  iter: 0                   # e.g., 120
  epoch: 0                  # e.g., 30
  avg: 1                    # how many checkpoints to average

data:
  test_data_config:
  max_duration: 1000
  on_the_fly_feats: True
  num_workers: 8
  
model:
  name: "asr-llm"   # Required
  speech_encoder_type: "whisper"
  speech_encoder_path: "/apdcephfs_qy3/share_302401520/user/bingshenmu/workspace/ailab_speech_llm/models/yuekai_whisper/whisper-large-v2-multi-hans-zh-epoch-3-avg-10.pt"
  llm_path: "/apdcephfs_qy3/share_302401520/user/bingshenmu/pretrained_models/Qwen2.5-7B-Instruct"
  use_flash_attn: True
  stage: 1
  pretrained_stage1_model_path:
  lora_config:
    lora_rank: 64
    lora_alpha: 16
    lora_dropout: 0.05
    target_modules: ["q_proj", "k_proj", "v_proj", "o_proj", "up_proj", "gate_proj", "down_proj"]
    task_type: "CAUSAL_LM"
  encoder_projector_ds_rate: 8
  subsampling_factor: 2 