 # 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: vicuna7b
  load_pretrained: True
  load_finetuned: False
  finetuned: ""
  stage1_url_or_filename: null
  image_model: "eva_clip_g"
  pc_model: "ulip_shapenet"
  video_model: "eva_clip_g"
  audio_model: "beats"
  pretrained_image_qformer: https://storage.googleapis.com/sfr-xinstructblip-data-research/model/xinstructblip_checkpoints/vicuna7b/image_qformer.pth
  pretrained_pc_qformer:   https://storage.googleapis.com/sfr-xinstructblip-data-research/model/xinstructblip_checkpoints/ulip_baselines/ulip1_objaverse_shapenet.pth
  pretrained_video_qformer: https://storage.googleapis.com/sfr-xinstructblip-data-research/model/xinstructblip_checkpoints/vicuna7b/video_qformer.pth
  pretrained_audio_qformer: https://storage.googleapis.com/sfr-xinstructblip-data-research/model/xinstructblip_checkpoints/vicuna7b/audio_qformer.pth
  load_attention_image_qformer: True
  load_attention_pc_qformer: True
  load_attention_video_qformer: True
  load_attention_audio_qformer: True
  load_ln_type_image: "image"
  load_ln_type_video: "video"
  load_ln_type_pc: "pc"
  load_ln_type_audio: "audio"
  load_qformer_type_image: "image"
  load_qformer_type_pc: "pc"
  load_qformer_type_video: "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: "image"
  load_projection_type_pc: "pc"
  load_projection_type_video: "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: /path/to/vicuna-7b
  prompt:  "describe the 3d model"
  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 :  ["pc"]
  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: ""

datasets:
  objaverse_mm_caption_instruct: # 651576 train examples
      vis_processor:
          train:
            name: "clip_image_train"
            image_size: 224
          eval:
            name: "clip_image_train"
            image_size: 224
      pc_processor:
            train:
              name: "ulip_pc"
            eval:
              name: "ulip_pc"
      text_processor:
          train:
            name: "blip_instruction"
            modality: pc
            task: caption
          eval:
            name: "blip_caption"

      data_type: [pc] # [images|pc]

      build_info:
        # Be careful not to append minus sign (-) before split to avoid itemizing
        annotations:
           train:
            url: 
              - https://storage.googleapis.com/sfr-xinstructblip-data-research/data/objaverse/cap3d_cap_final_train.csv
              # - /export/einstein-vision/3d_vision/objaverse_captions/objaverse_blip_captions_train.json
            storage:
              - objaverse/annotations/train.csv
              # - /export/einstein-vision/3d_vision/objaverse_captions/objaverse_blip_captions_train.json
          
           val:
             url: 
               # - https://storage.googleapis.com/sfr-xinstructblip-data-research/data/objaverse/cap3d_cap_final_val.csv
          #     - /export/einstein-vision/3d_vision/objaverse_captions/objaverse_blip_captions_val.json
             storage: 
               - objaverse/annotations/val.csv
              # - /export/einstein-vision/3d_vision/objaverse_captions/objaverse_blip_captions_val.json
        
        templates: null

        pc:
          storage: /export/einstein-vision/3d_vision/objaverse/objaverse_pc_parallel
        
        images:
          storage: /export/einstein-vision/3d_vision/objaverse_captions/images/


run:
  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: 1
  batch_size_train: 32
  batch_size_eval: 1
  num_workers: 8
  accum_grad_iters: 1

  max_len: 80
  min_len: 10
  num_beams: 5
  length_penalty: 0.
  prompt: "describe the 3d model"

  seed: 42
  output_dir: "output/xinstructblip/eval/vicuna7b/pc_ulip1_objaverse_shapenet/objaverse_captioning/"
  # annotation_file: /export/home/.cache/lavis/objaverse_mm_caption_instruct_gt/objaverse_mm_caption_instruct_val_annotations.json
  
  amp: True
  resume_ckpt_path: null
  caption_key: 'data'
  sample_id_key: sample_id

  evaluate: True
  # 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
  