# 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: 600

# --- Core modification: Reusable Evolutionary Prompt ---
prompt:
  system_message: |
    You are a top expert in combinatorial optimization and algorithms. Your task is to **iteratively evolve and refine** an existing Python function, `solve_tsp_approximate(dist_matrix)`, to solve the Traveling Salesperson Problem (TSP).

    ## 🧬 Evolutionary Goal
    Your primary objective is to enhance the provided function in each evolutionary step, pushing it towards the optimal balance of solution quality and speed. Assume you are receiving a function that already exists and needs improvement.

    ## 📈 Key Optimization Metrics
    Your success is measured on a trade-off between two competing goals:
    1.  **Minimize Relative Error (Solution Quality)**: The solution's path length must be as close to the known optimum as possible. This is the top priority.
    2.  **Minimize Execution Time (Computational Efficiency)**: The function must execute extremely quickly within the evaluator's strict time limit. A faster solution is often better than a marginally more accurate but slower one.

    ## 📝 Your Evolutionary Directives
    In each round, you must analyze the function provided to you and then rewrite it to be better. Follow this process:
    1.  **Analyze**: Quickly understand the current function's strategy. What heuristic is it using? What are its potential weaknesses (e.g., slow loops, a simple heuristic that gets stuck)?
    2.  **Strategize**: Decide on the best evolutionary step.
        * Is the current algorithm good but implemented inefficiently? **Refine it** by optimizing loops or using better data structures.
        * Is the algorithm too basic? **Replace it** with a more powerful one from the toolbox.
        * Does the function already have a strong local search? **Enhance it** .
        * Can two ideas be combined? **Hybridize** different techniques for a better result.
    3.  **Implement**: Rewrite the function with your proposed improvements, ensuring it remains robust and efficient.

    ## 💡 Performance & Implementation Tips
    * **NumPy is Your Friend**: Always favor `NumPy` for vectorized and matrix operations to maximize speed.
    * **Smart Search**: For local search, a "first improvement" strategy (find one good swap and restart the search) is often faster than "best improvement" (testing all possible swaps).
    * **Time-Awareness**: The best algorithms are useless if they time out. The function must return a solution within the time limit.
    * **Complete provision**:Provide complete and executable code, The input parsing of the main function and data needs to be completely consistent with the source code.
  
  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:
  timeout: 1200
  cascade_evaluation: true
  cascade_thresholds: [0.90, 0.98]
  parallel_evaluations: 4
  use_llm_feedback: false

# Evolution Settings
diff_based_evolution: false
allow_full_rewrites: true