project:
  name: CIRBench
  version: "0.3.0"
  seed: 1337
  output_dir: runs

tracks:
  - name: analysis
    enabled: true
    mode: direct
    k: 1
    budget: { time_s: 30, tokens: 0, mem_mb: 512 }
  - name: repair
    enabled: true
    mode: direct
    k: 1
    budget: { time_s: 60, tokens: 0, mem_mb: 512 }
  - name: refactor
    enabled: true
    mode: direct
    k: 1
    budget: { time_s: 60, tokens: 0, mem_mb: 512 }
  - name: transform
    enabled: true
    mode: guarded
    k: 1
    budget: { time_s: 60, tokens: 0, mem_mb: 512 }

validators:
  verifier: { enabled: true }
  equiv_intra: { enabled: false, timeout_s: 10 }
  spec: { enabled: false }
  obs:  { enabled: false }

guardrails:
  roi_required: false
  delta_limits: { max_inst_delta: 64, max_blocks_affected: 8 }
  struct_hash_lock_non_roi: false
  isa_whitelist: []

models:
  - kind: gemini
    name: gemini-2.5-flash
    params:
      model: gemini-2.5-flash
      temperature: 0.1
      top_p: 0.9
      max_output_tokens: 65536
      thinking: true

  - kind: qwen
    name: qwen3-max-preview
    params:
      stop_sequences: ["</IR_OUT>", "</CIR_JSON>"]
      temperature: 0.1
      top_p: 0.9
      max_continuations: 0
      extra_body:
        enable_thinking: true
        thinking_budget: 8192

  - kind: qwen
    name: qwen3-235b-a22b-thinking-2507
    params:
      stop_sequences: ["</IR_OUT>", "</CIR_JSON>"]
      temperature: 0.1
      top_p: 0.9
      max_continuations: 0
      extra_body:
        thinking_budget: 8192

  - kind: deepseek
    name: deepseek-v3.2-exp
    params:
      stop_sequences: ["</IR_OUT>", "</CIR_JSON>"]
      temperature: 0.1
      top_p: 0.9
      max_continuations: 0
      extra_body:
        enable_thinking: true
        thinking_budget: 8192

  - kind: gpt
    name: gpt-5
    params:
      stop_sequences: ["</IR_OUT>", "</CIR_JSON>"]
      temperature: 0.1
      top_p: 0.9
      max_continuations: 0

  - kind: gpt
    name: gpt-oss-120b
    params:
      stop_sequences: ["</IR_OUT>", "</CIR_JSON>"]
      temperature: 0.1
      top_p: 0.9
      max_continuations: 0

  # Grok (xAI)
  - kind: grok
    name: grok-4-fast-reasoning
    params:
      stop_sequences: ["</IR_OUT>", "</CIR_JSON>"]
      temperature: 0.1
      top_p: 0.9

  # Claude (Anthropic)
  - kind: claude
    name: claude-sonnet-4-5-20250929
    params:
      stop_sequences: ["</IR_OUT>", "</CIR_JSON>"]
      temperature: 0.1
      max_tokens: 65536
      timeout: 3600
      thinking:
        type: enabled
        budget_tokens: 8192

  - kind: claude
    name: claude-haiku-4-5-20251001
    params:
      stop_sequences: ["</IR_OUT>", "</CIR_JSON>"]
      temperature: 0.1
      max_tokens: 65536
      thinking:
        type: enabled
        budget_tokens: 8192

  - kind: llama
    name: llama-4-maverick
    params:
      temperature: 0.1
      top_p: 0.9
      max_tokens: 8192

logging:
  level: INFO
  dir: runs/logs
  json: true
  console_rich: true

toolchain:
  clang: ""
  clangxx: ""
  opt: ""
  llc: ""
  llvm_size: ""
  llvm_mca: ""
  llvm_as: ""
  alive_tv: ""

prompt_cfg:
  default_template: |
    {{ SHOTS }}
    You are an IR analysis assistant.
    Given LLVM IR:
    <IR>
    {{ RAW_IR }}
    </IR>
    {{ TASK }}
  enforce_blocks: true
  shots_dir: "prompts/shots"
  shots:
    - "<TASK>Answer strictly in JSON.</TASK>"
  track_templates:
    transform: |
      {{ SHOTS }}
      Objective: {{ OBJ }} with ROI {{ ROI_JSON }} and ISA {{ ISA_JSON }}.
      Return <CIR_JSON> + <IR_OUT> only.
