# Model arguments
model_name_or_path: google/gemma-7b
model_revision: main
tokenizer_name_or_path: google/gemma-7b-it
torch_dtype: bfloat16
attn_implementation: flash_attention_2
  

# LoRA arguments
use_peft: true
lora_r: 128
lora_alpha: 256
lora_dropout: 0.05
lora_target_modules:
- q_proj
- k_proj
- v_proj
- o_proj
- gate_proj
- up_proj
- down_proj

# Data training arguments
dataset_mixer:
  argilla/dpo-mix-7k: 1.0
auto_insert_empty_system_msg: false
dataset_splits:
- train
preprocessing_num_workers: 12
chat_template: "{{ bos_token }}{% if messages[0]['role'] == 'system' %}{{ raise_exception('System role not supported') }}{% endif %}{% for message in messages %}{% if (message['role'] == 'assistant') %}{% set role = 'model' %}{% else %}{% set role = message['role'] %}{% endif %}{{ '<start_of_turn>' + role + '\n' + message['content'] | trim + '<end_of_turn>\n' }}{% endfor %}{% if add_generation_prompt %}{{'<start_of_turn>model\n'}}{% endif %}"

# SFT trainer config
bf16: true
do_eval: False
beta: 0.5
gradient_accumulation_steps: 32
gradient_checkpointing: true
gradient_checkpointing_kwargs:
  use_reentrant: false
hub_strategy: every_save
learning_rate: 5.0e-5
log_level: info
logging_steps: 5  
logging_strategy: steps
lr_scheduler_type: cosine
max_length: 2048
max_steps: -1
num_train_epochs: 3
output_dir:  data/gemma-7b-cpo-basic-5e-5-v5
overwrite_output_dir: false
per_device_eval_batch_size: 8
per_device_train_batch_size: 1
push_to_hub: true
remove_unused_columns: true
report_to:
- tensorboard
- wandb
save_strategy: "steps"
save_steps: 100000
save_total_limit: 1
seed: 42
warmup_ratio: 0.1