config:
  (): custom_colbert.utils.train_custom_colbert_models.ColModelTrainingConfig
  output_dir: !path ../../../models/lora_CroissantCool-v0.2
  model:
    (): custom_colbert.utils.wrapper.AutoColModelWrapper
    pretrained_model_name_or_path: "croissantllm/CroissantCool-v0.2"
    attn_implementation: "flash_attention_2"
    quantization_config:
      (): transformers.BitsAndBytesConfig
      load_in_4bit: true
      bnb_4bit_quant_type: "nf4"
      bnb_4bit_compute_dtype:  "bfloat16"
      bnb_4bit_use_double_quant: true
      
  dataset_loading_func: !ext custom_colbert.utils.dataset_transformation.load_manu_embeddings
  loss_func:
    (): custom_colbert.loss.colbert_loss.ColbertLoss
  max_length: 256
  run_eval: true
  add_suffix: true
  tr_args:
    (): transformers.training_args.TrainingArguments
    output_dir: null
    overwrite_output_dir: true
    num_train_epochs: 3
    per_device_train_batch_size: 128
    gradient_accumulation_steps: 1
    per_device_eval_batch_size: 32
    dataloader_num_workers: 8
    bf16: true
    save_steps: 500
    eval_steps: 50
    eval_strategy: "steps"
    logging_steps: 10
    warmup_steps: 100
    learning_rate: 5e-5
    save_total_limit: 1

  peft_config:
    (): peft.LoraConfig
    r: 16
    lora_alpha: 32
    lora_dropout: 0.05
    bias: "none"
    task_type: "FEATURE_EXTRACTION"
    target_modules:
      - 'up_proj'
      - 'down_proj'
      - 'gate_proj'
      - 'k_proj'
      - 'q_proj'
      - 'v_proj'
      - 'o_proj'
