title: "Prompt for Generating Mathematical Interestingness Functions"

introduction: "You will create a function to evaluate the interestingness of mathematical concepts and theorems. This function will help focus exploratory search on the most promising directions in mathematical discovery."

context: "In automated mathematical discovery, we need to evaluate entities (concepts or theorems) based on how interesting they are. Your task is to create a function that scores mathematical entities on a scale from 0 (least interesting) to 1 (most interesting). The function will be used by a policy that decides which concepts to explore further."

# Imports required by the generated interestingness function
required_imports: |
  import math
  import numpy as np
  from typing import Dict, Any, List, Set, Optional, Union
  from frame.knowledge_base.knowledge_graph import KnowledgeGraph, NodeType

  from frame.interestingness.learning.dsl_primitives import (
      get_ancestors, get_descendants, get_construction_depth,
      get_in_degree, get_out_degree, get_construction_history_rule_names,
      get_entity_step_age, get_num_concepts, get_num_conjectures,
      get_entity_node_type, get_concept_category, get_input_arity, get_num_component_types,
      get_examples, get_nonexamples,
      get_num_construction_inputs, is_proven, create_weighted_interestingness_function
  )

# Section defining the prompt structure for One-Shot LLM Generation
one_shot_prompt:
  primitives_intro: "You have access to the following primitive functions that can be used in your interestingness function. Each primitive provides some information about a mathematical entity in the knowledge graph:"
  
  task: "Write a Python function called `calculate_interestingness` that takes an entity_id and a knowledge graph, and returns a float between 0 and 1 representing how interesting the entity is. Use the primitive functions to extract relevant features and combine them in a meaningful way.

  Your function should aim to identify entities that are:
  1. Not too simple and not overtly complicated and uninteresting.
  2. Likely to be fruitful for further exploration
  3. Have characteristics that mathematicians would find interesting
  4. Possess a good balance of generality and specificity

  You can use mathematical operations (arithmetic, min/max, etc.) and common Python libraries like math and numpy to combine the primitives in a way that captures interestingness. CONSTRAINTS:
  - You **MUST** respond with **only** the complete, syntactically correct Python code for the new function (`calculate_interestingness_vN`).
  - Include the `def calculate_interestingness_vN(...):` signature line and the function body. Add a concise docstring.
  - **DO NOT** include any introductory text, explanations, comments outside the function body, or usage examples in your response.
  - If you use any of the primitives or abstractions, make sure you use them correctly. Provide the right inputs as described in the documentation given about the primitives!
  - The descriptions of the primitives and abstractions indicate what arguments they take. Follow proper Python syntax. Watch out for potential division by zero errors."

  template: |
    def calculate_interestingness(entity_id: str, graph: KnowledgeGraph) -> float:
        """
        Calculate the interestingness of a mathematical entity.
        
        Args:
            entity_id: The ID of the entity in the knowledge graph
            graph: The knowledge graph containing all mathematical entities
            
        Returns:
            A float between 0 and 1 representing how interesting the entity is,
            where 0 is least interesting and 1 is most interesting
        """
        # Implement your interestingness scoring here
        # ...
        
        # Return a value between 0 and 1
        return score

  closing: "Make sure your function handles potential errors gracefully, for example by catching exceptions when calling primitives. The function should always return a valid float between 0 and 1, even if there are unexpected inputs or errors."


# Section defining the system prompt for the FunSearch Sampler LLM
funsearch_system_prompt: |
  You are an expert Python programming assistant specializing in evolving code based on performance feedback.

  You are participating in an evolutionary function discovery process (FunSearch) to find a high-performing Python function called `calculate_interestingness`. This function evaluates the 'interestingness' of mathematical entities within a knowledge graph.

  The user prompt contains several **example implementations** of this function (named `calculate_interestingness_v0`, `calculate_interestingness_v1`, etc.), showcasing different approaches that have shown some success. The prompt ends with the header for the **new function** you need to generate: `def calculate_interestingness_vN(entity_id: str, graph: KnowledgeGraph) -> float:`.

  Your specific task is to **generate a new, potentially improved version** of the `calculate_interestingness` function, named `calculate_interestingness_vN`. You should **analyze all the example functions** provided in the user prompt (`_v0` to `_v(N-1)`) to understand different successful strategies and potentially combine or adapt their ideas.

  The function you write will receive `entity_id` (string) and `graph` (a `KnowledgeGraph` object) as input. You can use the following methods on the `graph` object to get information about the entity (`entity_id`) or the graph itself, the description explains what arguments it takes:
  {primitives_section}

  {abstraction_section}

  You also have access to standard Python libraries like `math`. Do not use notation like `graph.METHOD_NAME(args)`, only `METHOD_NAME(args)` will work.

  The goal is to create a function that receives a higher score when evaluated, indicating it better captures mathematical interestingness.

  **Output Constraints:**
  - You **MUST** respond with **only** the complete, syntactically correct Python code for the new function (`calculate_interestingness_vN`).
  - Include the `def calculate_interestingness_vN(...):` signature line and the function body. Add a concise docstring.
  - **DO NOT** include any introductory text, explanations, comments outside the function body, or usage examples in your response.
  - Enclose the entire function definition within a single markdown code block like this:
  - If you use any of the primitives or abstractions, make sure you use them correctly by supplying the proper arguments. 
  - Try not to rely on the abstractions alone - use them in a compositional way, where you also implement some of the logic yourself (passing interesting arguments to the abstractions counts).
  - If an abstraction has a function which does something similar to what you want to do, but not exactly, you can just implement the logic yourself.
  - Try not to copy the examples exactly, but rather use them as inspiration to create a new, better, function that *can* be similar.
  - You do not have to use all primitives, and you do not have to make extremely complex functions if you don't think it necessary.
  - Watch out for potential division by zero errors.

  ```python
  def calculate_interestingness_vN(entity_id: str, graph: KnowledgeGraph) -> float:
      """A new function version inspired by provided examples."""
      # ... implementation ...
      return score
  ```

funsearch_abstraction_prompt_addon: |
  There is also a list of available abstractions that you can use to help you generate the new function, use them if you think they would be helpful.
  {abstraction_list}

# Data describing available DSL primitives
primitive_categories:
  "Graph Structure Primitives":
    description: "These primitives extract information about the entity's position in the knowledge graph."
    primitives:
      - name: "get_ancestors"
        return_type: "List[str]"
        description: "(entity_id, graph): Returns list of ancestor node IDs."
      - name: "get_descendants"
        return_type: "List[str]"
        description: "(entity_id, graph): Returns list of descendant node IDs."
      - name: "get_construction_depth"
        return_type: "int"
        description: "(entity_id, graph): Returns the longest path from a root node."
      - name: "get_in_degree"
        return_type: "int"
        description: "(entity_id, graph): Returns the number of direct parent nodes."
      - name: "get_out_degree"
        return_type: "int"
        description: "(entity_id, graph): Returns the number of direct child nodes."
      - name: "get_construction_history_rule_names"
        return_type: "List[str]"
        description: "(entity_id, graph): Returns list of rule names used in construction."
      - name: "get_entity_step_age"
        return_type: "int"
        description: "(entity_id, graph): Returns the entity's age in construction steps."
      - name: "get_num_concepts"
        return_type: "int"
        description: "(graph): Returns the total number of concepts."
      - name: "get_num_conjectures"
        return_type: "int"
        description: "(graph): Returns the total number of conjectures."
  
  "Entity Attribute Primitives":
    description: "These primitives extract information about the entity's attributes."
    primitives:
      - name: "get_entity_node_type"
        return_type: "float"
        description: "(entity_id, graph): Returns 'Concept', 'Conjecture', or 'Theorem' depending on the type of the entity."
      - name: "get_concept_category"
        return_type: "float"
        description: "(entity_id, graph): Returns 'Predicate', 'Function', or 'Constant' depending on the type of the entity."
      - name: "get_input_arity"
        return_type: "int"
        description: "(entity_id, graph): Returns input arity of the entity.."
      - name: "get_num_component_types"
        return_type: "int"
        description: "(entity_id, graph): Returns number of component types in examples."
  
  "Example/Non-Example Primitives":
    description: "These primitives extract information about examples and non-examples of the entity."
    primitives:
      - name: "get_examples"
        return_type: "List[Tuple[Int]]"
        description: "(entity_id, graph): Returns list of positive examples, each example is a tuple of ints."
      - name: "get_nonexamples"
        return_type: "List[Tuple[Int]]"
        description: "(entity_id, graph): Returns list of negative examples, each example is a tuple of ints."

  "Construction Step Primitives":
    description: "These primitives extract information about how the entity was constructed."
    primitives:
      - name: "get_num_construction_inputs"
        return_type: "int"
        description: "(entity_id, graph): Returns number of direct construction inputs."
  
  "Conjecture/Theorem Primitives":
    description: "These primitives extract information specific to conjectures and theorems."
    primitives:
      - name: "is_proven"
        return_type: "float"
        description: "(entity_id, graph): Returns 1.0 if proven theorem, 0.0 otherwise."

  "General Primitives":
    description: "These primitives are general purpose functions that can be used to create more complex interestingness functions."
    primitives:
      - name: "create_weighted_interestingness_function"
        return_type: "Callable"
        description: "(functions: List[Callable], weights: List[float]): Creates a weighted interestingness function from a list of interestingness functions and a list of weights."
