# OpenEvolve Default Configuration
# This file contains all available configuration options with sensible defaults
# You can use this as a template for your own configuration

# General settings
max_iterations: 100                  # Maximum number of evolution iterations
checkpoint_interval: 10               # Save checkpoints every N iterations
log_level: INFO                       # Logging level (DEBUG, INFO, WARNING, ERROR, CRITICAL)
#log_dir: null                         # Custom directory for logs (default: output_dir/logs)
#random_seed: null                     # Random seed for reproducibility (null = random)

# Evolution settings
diff_based_evolution: true            # Use diff-based evolution (true) or full rewrites (false)
#allow_full_rewrites: true            # Allow occasional full rewrites even in diff-based mode
max_code_length: 10000                # Maximum allowed code length in characters

# LLM configuration
llm:
  primary_model: gpt-4o
  primary_model_weight: 0.8
  secondary_model: gpt-4.1
  secondary_model_weight: 0.2
  api_base: https://api.openai.com/v1/
  api_key: 
    xxx
  temperature: 0.7
  top_p: 0.95
  max_tokens: 4096

# Prompt configuration
prompt:
  template_dir:                       # Custom directory for prompt templates
  system_message: "You are a GIS expert and experienced coder focused on evolving
    the GeoConformal Prediction algorithm using evolutionary strategies. Your primary
    objective is to minimize the interval score, optimizing for both average interval
    length (avg_interval_length) and distance to user-defined coverage (dist_to_coverage).
    The model must not be optimized based on the training set.\n\n1. Suggested Algorithmic
    Improvements:\n   - Implement adaptive bandwidth selection in kernel smoothing,
    adjusting for local density of calibration points.\n   - Use ensemble learning
    methods to enhance spatial prediction accuracy.\n   - Incorporate geographic features
    like road networks or population density in distance metrics for kernel weighting.\n\
    \   - Implement regularization techniques in the regression model to improve generalization
    on unseen data.\n\n2. Proposed New Operators/Parameters for OpenEvolve:\n   -
    Adaptive bandwidth function that varies with test point density.\n   - Hyperparameter
    tuning for the regression model (learning rate, depth, min_child_weight).\n  \
    \ - Evaluation metrics focusing on spatial features, such as spatial autocorrelation
    of residuals.\n   - Inclusion of temporal features for possible spatiotemporal
    analysis.\n\n3. Structured Prompt:\n- Initiate evolutionary search to optimize
    the GeoConformal Prediction algorithm, targeting reduced interval scores while
    ensuring model flexibility and accuracy.\n- Implement suggested algorithmic improvements
    and new operators; systematically evaluate performance via cross-validation on
    spatial datasets.\n- Constraints include not modifying the model on the training
    set, maintaining functional integrity within the existing framework, and ensuring
    scalability in processing.\n- Expected outputs include a refined model with lower
    interval scores, performance analysis against baseline metrics, and comprehensive
    documentation of evolutionary changes and testing protocols validating improvements.\n\
    \nEnsure each evolved version is benchmarked against previous iterations, clearly
    reporting avg_interval_length and dist_to_coverage metrics to monitor progress."
  evaluator_system_message: You are an expert code reviewer.

  # Number of examples to include in the prompt
  num_top_programs: 3                 # Number of top-performing programs to include
  num_diverse_programs: 2             # Number of diverse programs to include

  # Template stochasticity
  use_template_stochasticity: true    # Use random variations in templates for diversity
  template_variations:                # Different phrasings for parts of the template
    improvement_suggestion:
    - "Here's how we could improve this code:"
    - 'I suggest the following improvements:'
    - 'We can enhance this code by:'

  # Note: meta-prompting features are not yet implemented

# Database configuration
database:
  # General settings
  db_path:                            # Path to persist database (null = in-memory only)
  in_memory: true                     # Keep database in memory for faster access

  # Evolutionary parameters
  population_size: 50               # Maximum number of programs to keep in memory
  archive_size: 20                   # Size of elite archive
  num_islands: 3                      # Number of islands for island model (separate populations)

  # Island-based evolution parameters
  # Islands provide diversity by maintaining separate populations that evolve independently.
  # Migration periodically shares the best solutions between adjacent islands.
#  migration_interval: 50              # Migrate between islands every N generations
#  migration_rate: 0.1                 # Fraction of top programs to migrate (0.1 = 10%)

  # Selection parameters
  elite_selection_ratio: 0.1          # Ratio of elite programs to select
  exploration_ratio: 0.2              # Ratio of exploration vs exploitation
  exploitation_ratio: 0.7             # Ratio of exploitation vs random selection
  # Note: diversity_metric is fixed to "edit_distance" (feature_based not implemented)

  # Feature map dimensions for MAP-Elites
  feature_dimensions:                 # Dimensions for MAP-Elites feature map
  - score                             # Performance score
  - complexity                        # Code complexity (length)
  feature_bins: 10                    # Number of bins per dimension

# Evaluator configuration
evaluator:
  # General settings
  timeout: 300                        # Maximum evaluation time in seconds
  max_retries: 3                      # Maximum number of retries for evaluation

  # Note: resource limits (memory_limit_mb, cpu_limit) are not yet implemented

  # Evaluation strategies
  cascade_evaluation: false            # Use cascade evaluation to filter bad solutions early
  cascade_thresholds: # Thresholds for advancing to next evaluation stage
  - 0.5                               # First stage threshold
  - 0.75                              # Second stage threshold
  - 0.9                               # Third stage threshold

  # Parallel evaluation
  parallel_evaluations: 4             # Number of parallel evaluations
  # Note: distributed evaluation is not yet implemented

  # LLM-based feedback (experimental)
#  use_llm_feedback: true             # Use LLM to evaluate code quality
#  llm_feedback_weight: 0.1            # Weight for LLM feedback in final score
