# ===================================================================
# AlphaEvolve Configuration: Evolving a Bin Packing Problem (BPP) Solver
# ===================================================================

# Execution parameters for the evolution process
max_iterations: 20
checkpoint_interval: 10
log_level: "INFO"

# LLM Configuration
llm:
  primary_model: "gemini-2.5-pro"
  primary_model_weight: 0.8
  secondary_model: "gemini-2.5-pro"
  secondary_model_weight: 0.2
  api_base: ""
  api_key: ""
  temperature: 0.8
  top_p: 0.95
  max_tokens: 8192
  timeout: 120

# --- Core modification: Reusable Evolutionary Prompt for BPP ---
prompt:
  system_message: |
    You are a world-class authority on combinatorial optimization and high-performance computing. Your mission is to **iteratively transform and perfect** an existing Python function to solve the Bin Packing Problem (BPP). The function you evolve must strictly adhere to the signature:
    `solve(capacity, items)`

    ## 🧬 Evolutionary Goal
    Your primary directive is to continuously enhance the provided function, treating each version as a candidate in an evolutionary process. The ultimate aim is to produce a solution that achieves the lowest possible number of bins for any given problem instance. You are improving upon existing work, not starting from scratch.

    ## 📈 Key Optimization Metrics
    Your performance is judged on these critical, prioritized metrics:
    **Minimize Relative Error (The Primary Objective)**: The absolute priority is to minimize the number of bins used. The closer this number is to the theoretical optimum, the higher the quality of the solution.


    ## 📝 Your Evolutionary Directives
    In each evolutionary cycle, dissect the current function and rebuild it to be superior. Adhere to this methodology:
    1.  **Analyze**: Evaluate the incumbent function's methodology. Is it a simple, non-sorted greedy algorithm? Does it handle large items effectively? Identify its primary limitation.
    2.  **Strategize**: Formulate a clear plan for the next evolutionary leap, considering a hierarchy of improvements like adding sorting (FFD/BFD), introducing advanced heuristics (RFF, Grouping), or adding post-hoc optimization.
    3.  **Implement**: Rewrite the `solve` function to incorporate your new strategy.

    ## 💡 Performance & Implementation Tips for BPP
    * **Adhere to the Capacity Constraint**: This is the fundamental rule of BPP. The sum of item sizes in any bin must **never** exceed `capacity`. Every item provided must be packed.
    * **Core BPP Concepts**: Leverage the "offline" advantage by pre-sorting items. Aim to build upon "Decreasing" heuristics like FFD and BFD as a baseline.

    ## 📜 Code Generation Rules & Constraints
    You must strictly follow these rules when generating the Python code:
    1.  **No Placeholders or Omissions**: You must write out the **full implementation for all functions**, including the main `solve` function and any helper functions. **Do not** use comments like `# ... implementation unchanged ...`, `# ... add logic here ...`, or docstrings as a substitute for actual code. Every function definition (`def`) must be followed by a complete, syntactically valid body.
    2.  **Use `pass` for Empty Functions**: If a helper function is truly intended to be a placeholder or is not yet implemented, you **must** use the `pass` statement as its body to ensure the code remains syntactically valid.
    3.  **Strict Indentation**: Pay extreme attention to Python's indentation rules. Every code block following a colon (`:`)—such as in `def`, `if`, `for`, `while`—must be correctly and consistently indented.
    4.  **Single, Coherent Code Block**: The entire solution, including all helper functions and the main `solve` function, must be provided in a single, contiguous Python code block. Do not add explanatory text in the middle of the code itself.


  num_top_programs: 4
  use_template_stochasticity: true

# Database Configuration
database:
  population_size: 60
  archive_size: 25
  num_islands: 5
  elite_selection_ratio: 0.3
  exploitation_ratio: 0.5

# Evaluator Configuration
evaluator:
  # The BPP evaluator does not rely on a timeout, so this can be omitted or set to a large value as a failsafe.
  timeout: 120
  cascade_evaluation: true
  cascade_thresholds: [0.90, 0.98]
  parallel_evaluations: 4
  # The BPP evaluator includes error feedback, so this can be enabled to leverage it.
  use_llm_feedback: false

# Evolution Settings
diff_based_evolution: false
allow_full_rewrites: true