 # 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: https://storage.googleapis.com/sfr-xinstructblip-data-research/model/xinstructblip_checkpoints/vicuna13b/image_qformer.pth
  load_finetuned: False
  finetuned: ""
  stage1_url_or_filename: null
  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-xinstructblip-data-research/model/xinstructblip_checkpoints/vicuna13b/image_qformer.pth
  pretrained_pc_qformer: https://storage.googleapis.com/sfr-xinstructblip-data-research/model/xinstructblip_checkpoints/vicuna13b/pc_qformer.pth
  pretrained_video_qformer: https://storage.googleapis.com/sfr-xinstructblip-data-research/model/xinstructblip_checkpoints/vicuna13b/video_qformer.pth
  pretrained_audio_qformer: https://storage.googleapis.com/sfr-xinstructblip-data-research/model/xinstructblip_checkpoints/vicuna13b/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-13b"
  prompt: "question: {} answer:"
  modalities :  [image, 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
  special_qformer_input_prompt: "a short description"
  prefix:  "You are given two inputs. Select exactly one of the two by referece to its relative position (first or second, left or right) that best answers the question. "
  predict_with_gen: False
  use_caption: True
  use_describe: False
  enumerate_inputs: False
  add_space: True

datasets:
  image_pc_discrn: # name of the dataset builder
    vis_processor:
          train:
            name: "clip_image_train"
          eval:
            name: "clip_image_eval"
    pc_processor:
          train:
            name: "ulip_pc"
          eval:
            name: "ulip_pc"
    text_processor:
        train:
          name: "blip_caption"
        eval:
          name: "blip_caption"

    data_type: [images, pc] # [images|videos|features]

   
    build_info:
      kwargs:
        total: 100
        raw: True
        shuffle_modalities: False
        balance_labels: True
        dataset_name: objaverse
        classnames:  [image, 3d]
        ground_truth: False

      # Be careful not to append minus sign (-) before split to avoid itemizing
      annotations:
        val:
          url:
            - https://storage.googleapis.com/sfr-xinstructblip-data-research/data/discrn/objaverse.json
          storage: 
            - https://storage.googleapis.com/sfr-xinstructblip-data-research/data/discrn/objaverse.json
      pc:
        storage: /export/einstein-vision/3d_vision/objaverse/objaverse_pc_parallel
      
      images:
        storage: /export/einstein-vision/3d_vision/objaverse_captions/images/

run:
  task: discrn_qa
  # optimization-specific
  batch_size_train: 8
  batch_size_eval: 1
  num_workers: 2
  max_epoch: 1
  segments: 1

  # inference-specific
  max_len: 10
  min_len: 1
  length_penalty: -1.
  num_beams: 5
  inference_method: "generate"

  train_splits: ["train"]
  valid_splits: ["val"]
  # test_splits: ["test"]

  # distribution
  device: "cuda"
  world_size: 1
  dist_url: "env://"
  distributed: True
  use_dist_eval_sampler: False
 

  # model specific
  k_test: 128

  # misc
  seed: 42
  output_dir: "output/xinstructblip/eval/vicuna13b/discrn/image_3d_caption"

  evaluate: True
  save_freq: -1
