 # Copyright (c) 2022, 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_t5_instruct
  model_type: flant5xl
  load_pretrained: True
  prompt: "a short description"

datasets:
  vatex_caption:
    vis_processor:
          train:
            name: alpro_video_train
            n_frms: 4
            image_size: 224
            min_scale: 0.9
            max_scale: 1.0
          eval:
            name: alpro_video_eval
            n_frms: 4
            image_size: 224
            min_scale: 0.9
            max_scale: 1.0
    text_processor:
        train:
          name: "blip_caption"
        eval:
          name: "blip_caption"

    build_info:
      # Be careful not to append minus sign (-) before split to avoid itemizing
      annotations:
        train:
          url: https://storage.googleapis.com/sfr-vision-language-research/LAVIS/datasets/vatex/cap_train.json
          storage: vatex/annotations/cap_train.json
        val:
          url: https://storage.googleapis.com/sfr-vision-language-research/LAVIS/datasets/vatex/cap_val.json
          storage: vatex/annotations/cap_val.json
        test:
          # iWNXAYGh9cI_000004_000014.mp4 is corrupt and removed from youtube
          url: https://storage.googleapis.com/sfr-vision-language-research/LAVIS/datasets/vatex/cap_private_test.json
          storage: vatex/annotations/cap_test.json
      videos:
        storage: /export/video-language-dataset/data/vatex/


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: 16
  batch_size_eval: 1
  num_workers: 8
  accum_grad_iters: 1

  max_len: 80
  min_len: 10
  num_beams: 5
  inference_method: "generate"
  prompt: "describe the video"
  length_penalty: 1.


  seed: 42
  output_dir:  "output/instructblip/vatex_caption_flant5xl/"

  amp: True
  resume_ckpt_path: null

  evaluate: True
  # train_splits: ["train"]
  valid_splits: ["val"]
  annotation_file: /export/home/.cache/lavis/vatex_caption_gt/vatex_caption_val_annotations.json


  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