wandb:
  entity: null
  resume: 'auto'

experiment:
    project: "mmada-training-stage1"
    name: "mmada-training-stage1-llada-instruct"
    output_dir: "mmada-training-stage1-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"

model:
    vq_model:
        type: "magvitv2"
        vq_model_name: "showlab/magvitv2"
    mmada:
        pretrained_model_path: "GSAI-ML/LLaDA-8B-Instruct"
        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: "imagenet1k"
    und_type: "captioning"
    combined_loader_mode: "max_size_cycle"
    params:
        train_t2i_shards_path_or_url: "/path/to/your/datasets/imagenet-1k/data/train"
        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/falcon-refinedweb/data/data/*.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-aesthetic-12m-captions"
        external_cc12m_caption_path: "/path/to/your/datasets/cc12m/captions"
        validation_prompts_file: "validation_prompts/imagenet_prompts.txt"
        mmu_image_root: "MMaDA/mmu_validation"
        shuffle_buffer_size: 1000
        num_workers: 32
        resolution: 256
        pin_memory: True
        persistent_workers: True

    preprocessing:
        max_seq_length: 128 # for text tokens
        resolution: 256
        center_crop: False
        random_flip: False

optimizer:
    name: adamw
    params: # default adamw params
        learning_rate: 1e-4
        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

training:
    gradient_accumulation_steps: 2
    noise_type: "mask"
    batch_size_t2i: 7
    batch_size_lm: 2
    batch_size_mmu: 6
    mixed_precision: "bf16"
    enable_tf32: True
    seed: 10086
    max_train_steps: 500000
    overfit_one_batch: False
    cond_dropout_prob: 0.1
    min_masking_rate: 0.0
    label_smoothing: 0.0
    max_grad_norm: 1
    guidance_scale: 1.5
    generation_timesteps: 12
    t2i_coeff: 1.0
    lm_coeff: 0.1
    mmu_coeff: 1.0