### model
model_name_or_path: Qwen/Qwen3-1.7B
trust_remote_code: true
infer_dtype: float16

### method
stage: sft
do_train: true
finetuning_type: full
#deepspeed: examples/deepspeed/ds_z3_config.json  # choices: [ds_z0_config.json, ds_z2_config.json, ds_z3_config.json]

### dataset
dataset: sft_fact_checker
template: qwen3
cutoff_len: 2000
max_samples: 70000
overwrite_cache: true
preprocessing_num_workers: 16
dataloader_num_workers: 2
train_on_prompt: true

### output
output_dir: saves/qwen_2.5/full/qwen_1_7_0405_fact_checker
logging_steps: 5
save_steps: 3000
plot_loss: true
overwrite_output_dir: true
save_only_model: false
report_to: wandb  # choices: [none, wandb, tensorboard, swanlab, mlflow]

### train
per_device_train_batch_size: 2
gradient_accumulation_steps: 2
learning_rate: 1.0e-5
num_train_epochs: 1.0
lr_scheduler_type: cosine
warmup_ratio: 0.1
bf16: true
ddp_timeout: 180000000
resume_from_checkpoint: null

enable_liger_kernel: true
deepspeed: examples/deepspeed/ds_z3_config.json
flash_attn: fa2

# ### eval
# val_size: 0.01
# per_device_eval_batch_size: 1
# eval_strategy: steps
# eval_steps: 100