model:
  arch: img_spec_cdt
  model_type: blip2_t5
  load_finetuned: True
  finetuned: "./pretrained_weights/blip2_caption_flant5xl.pth"

  freeze_ldm: true

  use_distill: True

  queue_size: 65536

  vit_model: "eva_clip_g"
  image_size: 364
  vit_precision: "fp32"  # only for eva_clip_g
  freeze_vit: True

  ldm_configs:
    # Stable Diffusion specific
    base_learning_rate: 1.0e-04
    target: ldm.models.diffusion.ddpm.ImageEmbeddingConditionedLatentDiffusion
    params:
      embedding_dropout: 0.25
      parameterization: "v"
      linear_start: 0.00085
      linear_end: 0.0120
      log_every_t: 200
      timesteps: 1000
      first_stage_key: "jpg"
      cond_stage_key: "txt"
      image_size: 96
      channels: 4
      cond_stage_trainable: false
      conditioning_key: crossattn
      scale_factor: 0.18215
      monitor: val/loss_simple_ema
      use_ema: False

      embedder_config:
        target: lavis.models.ldm_models.models.modules.encoders.modules.ClipImageEmbedder
        params:
          model: "ViT-L/14"

      noise_aug_config:
        target: lavis.models.ldm_models.models.modules.encoders.modules.CLIPEmbeddingNoiseAugmentation
        params:
          clip_stats_path: "../stablediffusion-main/checkpoints/karlo_models/ViT-L-14_stats.th"
          timestep_dim: 768
          noise_schedule_config:
            timesteps: 1000
            beta_schedule: squaredcos_cap_v2

      unet_config:
        target: ldm.modules.diffusionmodules.openaimodel.UNetModel
        params:
          #        num_classes: "sequential"
          adm_in_channels: 1536
          use_checkpoint: True
          image_size: 32 # unused
          in_channels: 4
          out_channels: 4
          model_channels: 320
          attention_resolutions: [ 4, 2, 1 ]
          num_res_blocks: 2
          channel_mult: [ 1, 2, 4, 4 ]
          num_head_channels: 64 # need to fix for flash-attn
          use_spatial_transformer: True
          use_linear_in_transformer: True
          transformer_depth: 1
          context_dim: 1024
          legacy: False

      first_stage_config:
        target: ldm.models.autoencoder.AutoencoderKL
        params:
          embed_dim: 4
          monitor: val/rec_loss
          ddconfig:
            #          attn_type: "vanilla-xformers"
            double_z: true
            z_channels: 4
            resolution: 256
            in_channels: 3
            out_ch: 3
            ch: 128
            ch_mult:
              - 1
              - 2
              - 4
              - 4
            num_res_blocks: 2
            attn_resolutions: [ ]
            dropout: 0.0
          lossconfig:
            target: torch.nn.Identity

      cond_stage_config:
        target: ldm.modules.encoders.modules.FrozenOpenCLIPEmbedder
        params:
          freeze: True
          layer: "penultimate"

#    base_learning_rate: 1.0e-4
#  #  target: ldm.models.diffusion.ddpm.LatentDiffusion
#    params:
#      linear_start: 0.00085
#      linear_end: 0.0120
#      num_timesteps_cond: 1
#      log_every_t: 200
#      timesteps: 1000
#      first_stage_key: "jpg"
#      cond_stage_key: "txt"
#      image_size: 64
#      channels: 4
#      cond_stage_trainable: False
#      conditioning_key: crossattn
#      monitor: val/loss_simple_ema
#      scale_factor: 0.18215
#      use_ema: False  # we set this to false because this is an inference only config
#
#      unet_config:
#        target: ldm.modules.diffusionmodules.openaimodel.UNetModel
#        params:
#          use_checkpoint: False  # with_no_grad
#          use_fp16: True
#          image_size: 32 # unused
#          in_channels: 4
#          out_channels: 4
#          model_channels: 320
#          attention_resolutions: [ 4, 2, 1 ]
#          num_res_blocks: 2
#          channel_mult: [ 1, 2, 4, 4 ]
#          num_head_channels: 64 # need to fix for flash-attn
#          use_spatial_transformer: True
#          use_linear_in_transformer: True
#          transformer_depth: 1
#          context_dim: 1024
#          legacy: False
#
#      first_stage_config:
#        target: ldm.models.autoencoder.AutoencoderKL
#        params:
#          embed_dim: 4
#          monitor: val/rec_loss
#          ddconfig:
#            #attn_type: "vanilla-xformers"
#            double_z: true
#            z_channels: 4
#            resolution: 256
#            in_channels: 3
#            out_ch: 3
#            ch: 128
#            ch_mult:
#              - 1
#              - 2
#              - 4
#              - 4
#            num_res_blocks: 2
#            attn_resolutions: [ ]
#            dropout: 0.0
#          lossconfig:
#            target: torch.nn.Identity
#
#      cond_stage_config:
#        target: ldm.modules.encoders.modules.FrozenOpenCLIPEmbedder
#        params:
#          freeze: True
#          layer: "penultimate"


run:
  task: img_spec_cdt
  dr_size: 1000000
  # optimizer
  lr_sched: "linear_warmup_cosine_lr"
  init_lr: 1e-5
  min_lr: 1e-5
  weight_decay: 0.02
  
  train_splits: ["train"]
  valid_splits: ["train"]
  test_splits: []

  # model specific
  k_test: 128  # 128

  output_dir: "./output/unlearn/blip2_t5/img_spec_cdt"

  max_epoch: 10
  log_freq: 10

  # dataloading
  num_workers: 8
  batch_size_train: 2 #32
  batch_size_eval: 2 #64
  
  # distribution
  device: "cuda"
  world_size: 1
  dist_url: "env://"
  distributed: True
  use_dist_eval_sampler: False

  # misc
  seed: 42
  amp: False
  resume_ckpt_path: null
  evaluate: False

datasets:
  mixed_mllmu: # name of the dataset builder
    vis_processor:
        train:
          name: "MVAE_image_train"
          image_size: 364
        eval:
          name: "MVAE_image_eval"
          image_size: 364
    text_processor:
        train:
          name: "blip_caption"
        eval:
          name: "blip_caption"

