Spaces:
Runtime error
Runtime error
""" A module for generating custom prompt strings.""" | |
from __future__ import annotations | |
import json | |
from typing import Any | |
class PromptGenerator: | |
""" | |
A class for generating custom prompt strings based on constraints, commands, | |
resources, and performance evaluations. | |
""" | |
def __init__(self) -> None: | |
""" | |
Initialize the PromptGenerator object with empty lists of constraints, | |
commands, resources, and performance evaluations. | |
""" | |
self.constraints = [] | |
self.commands = [] | |
self.resources = [] | |
self.performance_evaluation = [] | |
self.response_format = { | |
"thoughts": { | |
"text": "thought", | |
"reasoning": "reasoning", | |
"plan": "- short bulleted\n- list that conveys\n- long-term plan", | |
"criticism": "constructive self-criticism", | |
"speak": "thoughts summary to say to user", | |
}, | |
"command": {"name": "command name", "args": {"arg name": "value"}}, | |
} | |
def add_constraint(self, constraint: str) -> None: | |
""" | |
Add a constraint to the constraints list. | |
Args: | |
constraint (str): The constraint to be added. | |
""" | |
self.constraints.append(constraint) | |
def add_command(self, command_label: str, command_name: str, args=None) -> None: | |
""" | |
Add a command to the commands list with a label, name, and optional arguments. | |
Args: | |
command_label (str): The label of the command. | |
command_name (str): The name of the command. | |
args (dict, optional): A dictionary containing argument names and their | |
values. Defaults to None. | |
""" | |
if args is None: | |
args = {} | |
command_args = {arg_key: arg_value for arg_key, arg_value in args.items()} | |
command = { | |
"label": command_label, | |
"name": command_name, | |
"args": command_args, | |
} | |
self.commands.append(command) | |
def _generate_command_string(self, command: dict[str, Any]) -> str: | |
""" | |
Generate a formatted string representation of a command. | |
Args: | |
command (dict): A dictionary containing command information. | |
Returns: | |
str: The formatted command string. | |
""" | |
args_string = ", ".join( | |
f'"{key}": "{value}"' for key, value in command["args"].items() | |
) | |
return f'{command["label"]}: "{command["name"]}", args: {args_string}' | |
def add_resource(self, resource: str) -> None: | |
""" | |
Add a resource to the resources list. | |
Args: | |
resource (str): The resource to be added. | |
""" | |
self.resources.append(resource) | |
def add_performance_evaluation(self, evaluation: str) -> None: | |
""" | |
Add a performance evaluation item to the performance_evaluation list. | |
Args: | |
evaluation (str): The evaluation item to be added. | |
""" | |
self.performance_evaluation.append(evaluation) | |
def _generate_numbered_list(self, items: list[Any], item_type="list") -> str: | |
""" | |
Generate a numbered list from given items based on the item_type. | |
Args: | |
items (list): A list of items to be numbered. | |
item_type (str, optional): The type of items in the list. | |
Defaults to 'list'. | |
Returns: | |
str: The formatted numbered list. | |
""" | |
if item_type == "command": | |
return "\n".join( | |
f"{i+1}. {self._generate_command_string(item)}" | |
for i, item in enumerate(items) | |
) | |
else: | |
return "\n".join(f"{i+1}. {item}" for i, item in enumerate(items)) | |
def generate_prompt_string(self) -> str: | |
""" | |
Generate a prompt string based on the constraints, commands, resources, | |
and performance evaluations. | |
Returns: | |
str: The generated prompt string. | |
""" | |
formatted_response_format = json.dumps(self.response_format, indent=4) | |
return ( | |
f"Constraints:\n{self._generate_numbered_list(self.constraints)}\n\n" | |
"Commands:\n" | |
f"{self._generate_numbered_list(self.commands, item_type='command')}\n\n" | |
f"Resources:\n{self._generate_numbered_list(self.resources)}\n\n" | |
"Performance Evaluation:\n" | |
f"{self._generate_numbered_list(self.performance_evaluation)}\n\n" | |
"You should only respond in JSON format as described below \nResponse" | |
f" Format: \n{formatted_response_format} \nEnsure the response can be" | |
" parsed by Python json.loads" | |
) | |