### 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: lora
lora_rank: 8
lora_target: all
freeze_vision_tower: true 
freeze_multi_modal_projector: true
freeze_language_model: false
# deepspeed: examples/deepspeed/ds_z3_config.json

### dataset
dataset: embhazard  # Hugging Face dataset: EMBGuard/EMBHazard_wo_filter_v1.0
template: qwen3_vl_nothink
cutoff_len: 60000
preprocessing_num_workers: 16
dataloader_num_workers: 4

### output
output_dir: saves/EMBHazard/train/qwen3-vl-2b_lora_only_language
logging_steps: 1
# save_steps: 500
save_strategy: epoch
plot_loss: true
overwrite_output_dir: true
save_only_model: true

report_to: wandb  # choices: [none, wandb, tensorboard, swanlab, mlflow]
run_name: qwen3vl-2b-lora-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
resume_from_checkpoint: null

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