# NOTE: Experiment config for funsearch experiments. Duplicates some settings from succ_zero_base,
# because of failure of recursive config loading in funsearch code, a bug which we get around here, but TODO fix later.

defaults:
  - succ_zero_base  # Inherit from base
  - _self_  # Allow this config to override base values
  - override hydra/job_logging: default
  - override hydra/hydra_logging: default

# # Note(_; 5/5): Due to some config loading issues, I've just pasted this directly here, change for diff FunSearch experiments.
initial_state:
  _target_: frame.knowledge_base.knowledge_graph.KnowledgeGraph
  name: "succ_zero_eq_initial"
  description: "Initial knowledge graph with Zero, Successor, and Equality"

  # Import settings
  import_from: "frame.knowledge_base.initial_concepts"
  concepts:
    - "create_zero_concept"
    - "create_successor_concept"
    - "create_equality_concept" 

# initial_state:
#   _target_: frame.knowledge_base.knowledge_graph.KnowledgeGraph
#   name: "arithmetic_basic_initial"
#   description: "Initial knowledge graph with arithmetic basic concepts"

#   # Import settings
#   import_from: "frame.knowledge_base.initial_concepts"
#   concepts:
#     - "create_zero_concept"
#     - "create_one_concept"
#     - "create_two_concept"
#     - "create_addition_concept"
#     - "create_multiplication_concept"
#     - "create_divides_concept"
#     - "create_leq_than_concept"
#     - "create_equality_concept" 

# Experiment settings override
experiment:
  name: "succ_zero_multi_generated_interestingness_eval"
  description: "Generate N interestingness functions and evaluate each M times, starting from successor and zero."
  max_steps: 1000
  num_episodes: 16
  num_workers: 2
  seed: 0 #${oc.env:RANDOM_SEED,12345}
  episode_timeout_seconds: 30 # Timeout for the main process waiting for a worker episode result

  # --- New settings for N x M Evaluation ---
  evaluate_multiple_interestingness: True
  num_interestingness_to_generate: 2
  # num_episodes_per_function is now represented by experiment.num_episodes
  # --- End of New settings ---

# Timeout settings
timeouts:
  rule_application: 0.6  # Rule application timeout in seconds (previously hardcoded as RULE_APPLICATION_TIMEOUT)
  example_verification: 0.01  # Example verification timeout in seconds (previously hardcoded as EXAMPLE_VERIFICATION_TIMEOUT)
  z3_prover: 0.01 # Timeout for Z3 proof attempts within an environment step
  z3_example_search: 0.5 # Timeout for Z3-based example/non-example search (in seconds)

# Z3 Usage Control
z3_usage:
  use_z3_prover: false # Attempt to prove/disprove conjectures using Z3
  use_z3_example_search: true # Use Z3 to find examples/non-examples for new concepts

# Policy configuration override
policy:
  _target_: frame.policies.interestingness_guided_policy.InterestingnessGuidedPolicy
  type: interestingness_guided
  params:
    concept_selection: INTERESTINGNESS
    action_selection: SIMULATE_AND_SCORE # TODO(_; 4/7): Change this back to SIMULATE_AND_SCORE when that implementation has been verified.
    top_k_concepts: 4
    temperature: 1.0
    generate_interestingness: True
    interestingness_function_path: ""
    action_selection_params:
      simulation_limit: 3

# Production Rules configuration (Explicitly added for manual loading via OmegaConf.load)
production_rules:
    # Specify the file containing the list of rules to use.
    # Instantiate_rules will parse this file and load uncommented rules.
    definition_file: "${hydra:runtime.cwd}/frame/configs/theory_building/production_rules/default.yaml"
    # Optional: Keep default_rules flag for fallback if definition_file is not specified?
    # default_rules: False

# Environment variables
env:
  INTERESTINGNESS_DEBUG: 1  # Enable interestingness debugging

# Logging configuration
logging:
  level: INFO
  checkpoint_frequency: 10

# Output settings
output:
  print_concepts: True
  print_graph: True
  save_visualizations: False

hydra:
  run:
    dir: ${oc.env:HYDRA_RUN_DIR}
  sweep:
    dir: multirun/${experiment.name}/${now:%Y-%m-%d}/${now:%H-%M-%S}
  job:
    chdir: True 