# Low settings configuration for FunSearch
# Based on funsearch.implementation.config but with minimal resources

defaults:
  - theory_building/production_rules: default  # Use all available rules
  - theory_building/interestingness: default  # Use default interestingness measures
  - theory_building/initial_state: succ_zero_eq # Default initial state
  # Note(_; 4/25): This is the initial state that will be used, can be subbed out for: succ_zero, succ_zero_eq and arithmetic_basic
  - interestingness: default  # Use default HR interestingness functions
  - _self_

programs_database:
  functions_per_prompt: 2
  num_islands: 1
  reset_period: 3600 # 1 hour in seconds
  cluster_sampling_temperature_init: 0.01
  cluster_sampling_temperature_period: 30000
samples_per_prompt: 2
num_samplers: 1 # Single-threaded setup
num_evaluators: 1 # Single-threaded setup

# LLM Config (For frame.tools.llm_caller)
llm:
  model_name: "gpt-4o" # Less expensive model
  temperature: 1.0
  top_p: 0.95
  max_tokens: 8192 # Reduced token count
  # API key should be set via environment variable OPENAI_API_KEY

# Path to the interestingness prompt YAML file
prompt_yaml_path: ${hydra:runtime.cwd}/frame/configs/prompts/interestingness_prompt.yaml

# FRAME Evaluation Settings (used by TheoryBuilderSandbox)
# NOTE: base_theory_builder_config is now expected via command-line override or parent config
# tb_config_path: ??? # REQUIRED: Set via command line: python -m frame.funsearch.main tb_config_path=/path/to/your/tb_config.yaml
tb_config_path: "${hydra:runtime.cwd}/frame/configs/funsearch-test_succ_zero.yaml" # Provide the default (which is the generate_interestingness exp)
frame: 
  evaluation_episodes_M: 1 # Reduced episodes count (M)
  evaluation_timeout_seconds: 15 # Reduced timeout to 5 minutes
  save_eval_visualizations: true # Flag to enable visualizations during evaluation

# Template/Specification File
spec_path: "${hydra:runtime.cwd}/frame/funsearch/interestingness_spec.py"

# Persistence
database_backup_path: "${hydra:runtime.output_dir}/population_backup.pkl"
backup_frequency_seconds: 300 # Save DB every 5 minutes

# Output Dirs
output_directory: "${hydra:runtime.output_dir}"
evaluations_dir: "${hydra:runtime.output_dir}/evaluations"

# Note(_; 5/5): This was introduced because of some bug with Hydra not loading the initial state correctly, I opted for the hacky fix for now.
initial_state: "${hydra:runtime.cwd}/frame/configs/theory_building/initial_state/succ_zero_eq.yaml"

# Iterations of the Funsearch sampling loop
iterations: 4

# --- FunSearch Abstraction Settings ---
abstraction:
  enabled: true                      # Master switch: set to false to disable the entire abstraction mechanism
  frequency: 1                      # Run the abstraction step every N main FunSearch iterations (low for testing).
  programs_to_sample: 2              # How many top programs to analyze (low for testing).
  max_abstractions_per_step: 2       # Target new abstractions per step (low for testing).
  # Optional LLM override block for abstraction task
  llm:
    model_name: null                 # Default: null (use main llm config)
    temperature: null                # Default: null (use main llm config)
    top_p: null                      # Default: null (use main llm config)
    max_tokens: 1500                 # Can override max tokens if needed
  prompt_yaml_path: "${hydra:runtime.cwd}/frame/configs/prompts/abstraction_prompt.yaml" # Specific instructions for generating abstractions

# Hydra settings
hydra:
  run:
    dir: outputs/funsearch_runs/${now:%Y-%m-%d}/${now:%H-%M-%S}
  job:
    chdir: true 