# Model arguments
model_name_or_path:
model_revision: main
torch_dtype: bfloat16
use_flash_attention_2: True

# Data training arguments
chat_template: "{% set loop_messages = messages %}{% for message in loop_messages %}{% set content = '<|start_header_id|>' + message['role'] + '<|end_header_id|>\n\n'+ message['content'] | trim + '<|eot_id|>' %}{% if loop.index0 == 0 %}{% set content = bos_token + content %}{% endif %}{{ content }}{% endfor %}{% if add_generation_prompt %}{{ '<|start_header_id|>assistant<|end_header_id|>\n\n' }}{% endif %}"
dataset_mixer:
  data/my: 1.0
dataset_splits:
- train
preprocessing_num_workers: 64

# SFT trainer config
bf16: True
do_eval: False
evaluation_strategy: epoch
gradient_accumulation_steps: 4
gradient_checkpointing: True
gradient_checkpointing_kwargs:
  use_reentrant: False
learning_rate: 1.0e-05
log_level: info
logging_steps: 1  
logging_strategy: steps
lr_scheduler_type: cosine
max_seq_length: 2048
num_train_epochs: 3
output_dir: output/backtrack-8b-sft-full
overwrite_output_dir: True
per_device_eval_batch_size: 8
per_device_train_batch_size: 4
push_to_hub: False
remove_unused_columns: True
report_to:
- tensorboard
save_strategy: "steps"
save_steps: 300
save_total_limit: 30
seed: 42
warmup_ratio: 0.1