wandb:
  entity: null
#  run_id: askkz9i2
  resume: 'auto'

experiment:
    project: "mmada-training-stage3"
    name: "mmada-training-stage3-llada-instruct"
    output_dir: "mmada-training-stage3-llada-instruct"
    max_train_examples_t2i: 40000000    # 
    max_train_examples_mmu: 40000000    #
    save_every: 10000
    eval_every: 2500
    generate_every: 1000
    log_every: 50
    log_grad_norm_every: 100
    resume_from_checkpoint: "latest"
    val_every: 50
    max_val_examples_t2i: 2000

model:
    vq_model:
        type: "magvitv2"
        vq_model_name: "showlab/magvitv2"

    mmada:
        tokenizer_path: "GSAI-ML/LLaDA-8B-Instruct"
        pretrained_model_path: "path/to/your/checkpoint"
        w_clip_vit: False
        new_vocab_size: 134656
        llm_vocab_size: 126464
        codebook_size: 8192
        num_vq_tokens: 256
        num_new_special_tokens: 0
        tie_word_embeddings: False

    gradient_checkpointing: True

dataset:
    gen_type: "t2i"
    und_type: "captioning"
    combined_loader_mode: "max_size_cycle"
    params:
        train_t2i_shards_path_or_url: [     #
                                        "/path/to/your/datasets/JourneyDB/train/imgs/data/train/imgs/{000..199}.tgz",
                                        "/path/to/your/datasets/laion-aesthetics-12m/{00000..00999}.tar",
                                        "/path/to/your/datasets/text-to-image-2M/data_512_2M"
        ]
        train_mmu_shards_path_or_url: [ "/path/to/your/datasets/SA-1B/sa_{000000..000999}.tar",  #
                                        "/path/to/your/datasets/cc12m/raw/raw/{0000..0999}.tar",
                                      "/path/to/your/datasets/laion-aesthetics-12m/{00000..00999}.tar" 
        ]
        train_lm_shards_path_or_url: "/path/to/your/datasets/3-instruct-datasets/parquet/*.parquet"
        add_caption_prompt: True
        external_caption_path: "/path/to/your/datasets/SAM-LLaVA-Captions10M"
        external_journeydb_caption_path: "/path/to/your/datasets/journeydb_anno/train_journeydb_anno.json"
        external_laion12m_caption_path: "/path/to/your/datasets/laion-aesthetics-12m-images-2"
        external_cc12m_caption_path: "/path/to/your/datasets/cc12m/new_captions"
        external_text_to_image_2M_512_caption_path: "/path/to/your/datasets/text-to-image-2M/data_512_2M_captions"
        validation_prompts_file: "validation_prompts/text2image_prompts.txt"
        mmu_image_root: "/path/to/your/datasets/MMaDA/mmu_validation"
        lm_chat_validation_jsonl: "/path/to/your/datasets/MMaDA/lm_chat_validation/questions.jsonl"
        shuffle_buffer_size: 1000
        num_workers: 32
        resolution: 512
        pin_memory: True
        persistent_workers: True

    preprocessing:
        max_seq_length: 512 # for text tokens   512
        resolution: 512
        center_crop: False
        random_flip: False

optimizer:
    name: adamw
    params: # default adamw params
        learning_rate: 5e-5
        scale_lr: False # scale learning rate by total batch size
        beta1: 0.9
        beta2: 0.999
        weight_decay: 0.01
        epsilon: 1e-8

lr_scheduler:
    scheduler: "cosine"
    params:
        learning_rate: ${optimizer.params.learning_rate}
        warmup_steps: 5000
        min_lr_scale: 0.1

training:
    gradient_accumulation_steps: 4  # 4
    noise_type: "mask"
    batch_size_t2i: 4   # 3~4
    batch_size_lm: 1
    batch_size_mmu: 1
    mixed_precision: "bf16"
    enable_tf32: True
    seed: 10086
    max_train_steps: 1000000
    overfit_one_batch: False
    cond_dropout_prob: 0.1
    min_masking_rate: 0.0
    label_smoothing: 0.0
    max_grad_norm: 1
    guidance_scale: 3
    generation_timesteps: 12
    t2i_coeff: 1.0
    lm_coeff: 0.4 # ~0.5
    mmu_coeff: 0.5
    validation_seed: 42