interaction:
  - name: "ver_k_retry"
    class_name: "verl.interactions.ver_k_retry_interaction.VerKRetryInteraction"
    config:
      # Choose verifier:
      # - gsm8k_strict: uses verl.utils.reward_score.gsm8k.compute_score (expects #### format)
      # - exact_match: compares extracted answer to ground_truth (use with boxed extraction)
      # - callable: provide verifier_fn_path
      verifier_type: "callable"
      verifier_fn_path: "examples.reward_fns.boxed_answer_reward:verifier_fn"

      answer_extraction: "boxed"  # expects "\boxed{<answer>}"

      include_history: false
      history_max_chars: 0

      track_turn_metadata: true
      log_attempts: true
      log_attempts_num_samples: 3  # log this many interactions per run
      log_attempts_max_per_instance: 0  # 0 = no cap; log all steps for selected samples
      log_max_chars: 0  # 0 disables truncation; log full responses
      log_file: "./outputs/ver_k_retry_attempts.log"
      log_file_overwrite: true

      feedback:
        correct: "Correct. Stop."
        incorrect: |
          Your previous attempt(s) were incorrect. Review them and try again.
          Solve the problem again from scratch, correcting any mistakes.
          Final answer must be `\boxed{<answer>}`.
        max_attempts_reached: "Incorrect and maximum attempts reached. Stop."
