### model
model_name_or_path: Qwen/Qwen3-VL-2B-Instruct
image_max_pixels: 262144
video_max_pixels: 16384
trust_remote_code: true

### method
stage: sft
do_train: true
finetuning_type: full
freeze_vision_tower: true 
freeze_multi_modal_projector: true
freeze_language_model: false
deepspeed: examples/deepspeed/ds_z3_config.json

### dataset
dataset: embhazard
template: qwen3_vl_nothink
cutoff_len: 60000
preprocessing_num_workers: 32
dataloader_num_workers: 8

### output
output_dir: saves/EMBGuard/train/qwen3-vl-2b_only_language
# save_steps: 500
save_strategy: epoch
plot_loss: true
overwrite_output_dir: true
save_only_model: false

### wandb
report_to: wandb  # choices: [none, wandb, tensorboard, swanlab, mlflow]
run_name: qwen3vl-2b-full-embguard-v1-only_language  # Optional: wandb run name

### train
per_device_train_batch_size: 1
gradient_accumulation_steps: 8
learning_rate: 1.0e-5
num_train_epochs: 4.0
lr_scheduler_type: cosine
warmup_ratio: 0.05
bf16: true
ddp_timeout: 180000000

### eval
# val_size: 0.1
# per_device_eval_batch_size: 1
# eval_strategy: steps
# eval_steps: 500
