 # Copyright (c) 2023 salesforce.com inc.
 # All rights reserved.
 # SPDX-License-Identifier: BSD-3-Clause
 # For full license text see the LICENSE file in the repo root or https://opensource.org/licenses/BSD-3-Clause

model:
  arch: blip2_vicuna_xinstruct
  model_type: vicuna13b
  load_pretrained: True
  pretrained: /export/home/LAVIS-xgen_mm/lavis/output/xinstructblip/train/vicuna13b/audio/20231027135/checkpoint_240007.pth
  load_finetuned: False
  finetuned: ""
  stage1_url_or_filename: https://storage.googleapis.com/sfr-vision-language-research/LAVIS/models/BLIP2/blip2_pretrained.pth
  image_model: "eva_clip_g"
  pc_model: "ulip2_pointbert"
  video_model: "eva_clip_g"
  audio_model: "beats"
  pretrained_image_qformer: https://storage.googleapis.com/sfr-vision-language-research/LAVIS/models/BLIP2/blip2_pretrained.pth
  pretrained_pc_qformer:  https://storage.googleapis.com/sfr-vision-language-research/LAVIS/models/BLIP2/blip2_pretrained.pth
  pretrained_video_qformer: https://storage.googleapis.com/sfr-vision-language-research/LAVIS/models/BLIP2/blip2_pretrained.pth
  pretrained_audio_qformer: /export/home/LAVIS-xgen_mm/lavis/output/xinstructblip/train/vicuna13b/audio/20231027135/checkpoint_240007.pth
  load_attention_image_qformer: False
  load_attention_pc_qformer: False
  load_attention_video_qformer: False
  load_attention_audio_qformer: True
  load_ln_type_image: ""
  load_ln_type_video: ""
  load_ln_type_pc: ""
  load_ln_type_audio: "audio"
  load_qformer_type_image: ""
  load_qformer_type_pc: ""
  load_qformer_type_video: ""
  load_qformer_type_audio: "audio"
  load_projection_image: True
  load_projection_pc: True
  load_projection_video: True
  load_projection_audio: True
  load_projection_type_image: ""
  load_projection_type_pc: ""
  load_projection_type_video: ""
  load_projection_type_audio: "audio"
  image_encoder_kwargs :  {"image_size": 224, "drop_path_rate": 0, "use_grad_checkpoint": False}
  pc_encoder_kwargs :  {}
  video_encoder_kwargs :   {"image_size": 224, "drop_path_rate": 0, "use_grad_checkpoint": False}
  audio_encoder_kwargs :  {}
  image_precision: "fp16"
  pc_precision: "fp16"
  video_precision: "fp16"
  audio_precision: "fp16"
  freeze_image: True
  freeze_pc: True
  freeze_video: True
  freeze_audio: True
  num_query_token: 32
  llm_model: "/export/home/LAVIS/_pretrained_models/vicuna-13b"
  prompt:  "describe the audio."
  max_txt_len: 128
  max_output_txt_len: 256
  apply_lemmatizer: False
  num_few_shot_examples: 0
  few_shot_prob: 0
  qformer_text_input: True
  llm_text_input: True
  modalities :  ["audio"]
  use_cues: True
  shared_qformer: False
  pretrained_shared_qformer: Null
  load_attention_shared_qformer: False
  load_qformer_type_shared: ""
  load_projection_shared: False
  load_projection_type_shaped: ""
  load_ln_type_shared: ""
  shared_qformer_num_features: 512
  prefix: ""
  postfix: ""
  predict_with_gen: False


datasets:
  ## CAPTIONING TASKS
  audiocaps_mm_caption_instruct: #  38701 train examples
    audio_processor:
        train:
          name: beats_audio
          sampling_rate: 16000
        eval:
          name: beats_audio
          sampling_rate: 16000
          
    text_processor:
        train:
          name: "blip_instruction"
          modality: audio
          task: caption
        eval:
          name: "blip_caption"

    data_type: [audio]

    build_info:
      kwargs:
          missing_ids: [2sh7ZkazyO8, 966jA2-z0mQ, 52RlolYyjAE, HVAc9hm4jjk, 8lPjqvYWNyM, eXgPnnE3TuQ]
      annotations:
        train:
          url: 
            - https://raw.githubusercontent.com/cdjkim/audiocaps/master/dataset/train.csv
          storage: 
            - audiocaps/annotations/train.csv
          
        val:
          url: 
            - https://raw.githubusercontent.com/cdjkim/audiocaps/master/dataset/val.csv
          storage: 
            - audiocaps/annotation/val.csv

        # test:
        #   url: 
        #     - https://raw.githubusercontent.com/cdjkim/audiocaps/master/dataset/test.csv
        #   storage: 
        #     - /export/einstein-vision/audio_datasets/audiocaps/dataset/test.csv
            
      audio:
        storage: /export/einstein-vision/audio_datasets/audiocaps/AUDIOCAPS_32000Hz/audio


  audiocaps_mm_qa: # 24158
    audio_processor:
        train:
          name: beats_audio
          sampling_rate: 16000
        eval:
          name: beats_audio
          sampling_rate: 16000
          is_eval: True
          
    text_processor:
        train:
          name: "blip_instruction"
          modality: audio
          task: qa
        eval:
          name: "blip_question"

    data_type: [audio] 

    build_info:
      kwargs:
        missing_ids: [2sh7ZkazyO8, 966jA2-z0mQ, 52RlolYyjAE, HVAc9hm4jjk, 8lPjqvYWNyM, eXgPnnE3TuQ]
      annotations:
        train:
          url: 
            - /export/home/LAVIS/projects/mm_instructblip/instr_data_creation/audio_qa/audio_qa_final_train.csv
          storage: 
            - /export/home/LAVIS/projects/mm_instructblip/instr_data_creation/audio_qa/audio_qa_final_train.csv
          
        # val:
        #   url: 
        #     - /export/home/LAVIS/projects/mm_instructblip/instr_data_creation/audio_qa/audio_qa_final_val.csv
        #   storage: 
        #     - /export/home/LAVIS/projects/mm_instructblip/instr_data_creation/audio_qa/audio_qa_final_val.csv

      audio:
        storage: /export/einstein-vision/audio_datasets/audiocaps/AUDIOCAPS_32000Hz/audio
  
  
  ## Classification like caption
  audioset_mm_caption_instruct: # 14141
    audio_processor:
        train:
          name: beats_audio
          sampling_rate: 16000
        eval:
          name: beats_audio
          sampling_rate: 16000
          is_eval: False
          
    text_processor:
        train:
          name: blip_instruction
          modality: audio
          task: classification
          cmu_dict_path: /export/home/LAVIS/cmu_dict.p
        eval:
          name: blip_caption

    data_type: [audio] 

    build_info:
      annotations:
        train:
          url: 
            - /export/home/LAVIS-xgen_mm/lavis/configs/datasets/audioset/balanced_train_clean.csv
            - http://storage.googleapis.com/us_audioset/youtube_corpus/v1/csv/class_labels_indices.csv
          storage: 
            - /export/home/LAVIS-xgen_mm/lavis/configs/datasets/audioset/balanced_train_clean.csv
            - audioset/annotations/class_labels_indices.csv
        # val:
        #   url: 
        #     - http://storage.googleapis.com/us_audioset/youtube_corpus/v1/csv/eval_segments.csv
        #     - http://storage.googleapis.com/us_audioset/youtube_corpus/v1/csv/class_labels_indices.csv
        #   storage: 
        #     - audioset/annotations/eval_segments.csv
        #     - audioset/annotations/class_labels_indices.csv
      audio:
        storage: /export/einstein-vision/audio_datasets/AudioSet/all_audio

  wavcaps_mm_caption_instruct: # 297341 examples
    audio_processor:
        train:
          name: beats_audio
          sampling_rate: 16000
          n_frames: 2
          frame_length: 512
        eval:
          name: beats_audio
          sampling_rate: 16000
          n_frames: 2
          frame_length: 512
    text_processor:
        train:
          name: "blip_instruction"
          modality: audio
          task: caption
        eval:
          name: "blip_caption"

    data_type: [audio] 

    build_info:
      kwargs:
        json_data: /export/share/datasets/audio/WavCaps/json_data.json

        cached: False
        cached_dir: /export/share/datasets/audio/WavCaps/beats_features/

      # Be careful not to append minus sign (-) before split to avoid itemizing
      annotations:
        train:
          url: 
            - /export/share/datasets/audio/WavCaps/json_files/BBC_Sound_Effects/bbc_final.json
            - /export/share/datasets/audio/WavCaps/json_files/FreeSound/fsd_final.json
            - /export/share/datasets/audio/WavCaps/json_files/SoundBible/sb_final.json
            - /export/share/datasets/audio/WavCaps/json_files/AudioSet_SL/as_final.json
            - /export/share/datasets/audio/WavCaps/json_data.json
          storage: 
            - /export/share/datasets/audio/WavCaps/json_files/BBC_Sound_Effects/bbc_final.json
            - /export/share/datasets/audio/WavCaps/json_files/FreeSound/fsd_final.json
            - /export/share/datasets/audio/WavCaps/json_files/SoundBible/sb_final.json
            - /export/share/datasets/audio/WavCaps/json_files/AudioSet_SL/as_final.json
            - /export/share/datasets/audio/WavCaps/json_data.json
          
      audio:
        storage: /export/share/datasets/audio/WavCaps/
  
  

run:
  runner: runner_iter
  task: captioning
  # optimizer
  lr_sched: "linear_warmup_cosine_lr"
  init_lr: 1e-5
  min_lr: 0
  warmup_lr: 1e-8
  warmup_steps: 1000
  weight_decay: 0.05
  max_epoch: 40
  batch_size_train: 2
  batch_size_eval: 2
  num_workers: 10
  accum_grad_iters: 1
  max_iters: 300000
  iters_per_inner_epoch: 5000
  train_dataset_ratios: {"audiocaps_mm_caption_instruct": 0.19355908897689844, "audiocaps_mm_qa": 0.1529265758175233, "wavcaps_mm_caption_instruct": 0.5365125368594943,  "audioset_mm_caption_instruct": 0.11700179834608398}

  max_len: 30
  min_len: 1
  num_beams: 5
  caption_key: caption
  sample_id_key: youtube_id
  annotation_file: /export/home/.cache/lavis/audiocaps_mm_caption_instruct_gt/audiocaps_mm_caption_instruct_val_annotations.json

  seed: 42
  output_dir: "output/xinstructblip/train/vicuna13b/audio"

  amp: True
  resume_ckpt_path: /export/home/LAVIS-xgen_mm/lavis/output/xinstructblip/train/vicuna13b/audio/20231027135/checkpoint_240007.pth

  evaluate: False
  train_splits: ["train"]
  # valid_splits: ["val"]


  device: "cuda"
  world_size: 1
  dist_url: "env://"
  distributed: True
  save_freq: 1 # save epoch every xxx epochs -1 only save last and best. 
  val_freq: 1
