model:
  arch: txt_spec_cdt
  model_type: blip2_t5
  load_finetuned: True

  pretrained: "https://storage.googleapis.com/sfr-vision-language-research/LAVIS/models/BLIP2/blip2_pretrained_flant5xl.pth"
  finetuned: "https://storage.googleapis.com/sfr-vision-language-research/LAVIS/models/BLIP2/blip2_caption_flant5xl.pth"

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

  # Q-Former
  num_query_token: 32

  # T5
  t5_model: "google/flan-t5-xl"

  # generation configs
  prompt: "Generate a description of this scene: "

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

  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"


datasets:
  mixed_mllmu: # name of the dataset builder
    data_type: images
    vis_processor:
      train:
        name: "blip_image_train"
        image_size: 364
      eval:
        name: "blip_image_eval"
        image_size: 364
    text_processor:
      train:
        name: "blip_caption"
      eval:
        name: "blip_caption"

run:
  runner: runner_gene_image
  task: image_gene
  gpu: True
  # optimizer
  lr_sched: "linear_warmup_cosine_lr"
  init_lr: 2e-5
  min_lr: 0
  weight_decay: 0.04

  # inference-specific
  max_len: 30
  min_len: 10
  num_beams: 3

  output_dir: "./output/generation/SD/image_generation_mllmu"

  max_epoch: 5
  log_freq: 20

  # misc
  seed: 42

  amp: False
  resume_ckpt_path: null
  evaluate: True

  # dataloading
  num_workers: 0
  batch_size_train: 8
  batch_size_eval: 1

  train_splits: ["train"]
  valid_splits: ["train"]
  test_splits: ["train"]

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