Spaces:
Build error
Build error
from __future__ import annotations | |
import asyncio | |
from colorama import Fore | |
from agentverse.logging import get_logger | |
import bdb | |
from string import Template | |
from typing import TYPE_CHECKING, List, Tuple | |
# from agentverse.environments import PipelineEnvironment | |
from agentverse.message import SolverMessage, Message, CriticMessage | |
from agentverse.agents import agent_registry | |
from agentverse.agents.base import BaseAgent | |
from agentverse.utils import AgentCriticism | |
logger = get_logger() | |
class SolverAgent(BaseAgent): | |
max_history: int = 3 | |
def step( | |
self, former_solution: str, advice: str, task_description: str = "", **kwargs | |
) -> SolverMessage: | |
logger.debug("", self.name, Fore.MAGENTA) | |
# prompt = self._fill_prompt_template( | |
# former_solution, critic_opinions, advice, task_description | |
# ) | |
prepend_prompt, append_prompt = self.get_all_prompts( | |
former_solution=former_solution, | |
task_description=task_description, | |
advice=advice, | |
role_description=self.role_description, | |
**kwargs, | |
) | |
history = self.memory.to_messages(self.name, start_index=-self.max_history) | |
parsed_response = None | |
for i in range(self.max_retry): | |
try: | |
response = self.llm.generate_response( | |
prepend_prompt, history, append_prompt | |
) | |
parsed_response = self.output_parser.parse(response) | |
break | |
except (KeyboardInterrupt, bdb.BdbQuit): | |
raise | |
except Exception as e: | |
logger.error(e) | |
logger.warn("Retrying...") | |
continue | |
if parsed_response is None: | |
logger.error(f"{self.name} failed to generate valid response.") | |
message = SolverMessage( | |
content="" | |
if parsed_response is None | |
else parsed_response.return_values["output"], | |
sender=self.name, | |
receiver=self.get_receiver(), | |
) | |
return message | |
async def astep(self, env_description: str = "") -> SolverMessage: | |
"""Asynchronous version of step""" | |
pass | |
def _fill_prompt_template( | |
self, | |
former_solution: str, | |
critic_opinions: List[AgentCriticism], | |
advice: str, | |
task_description: str, | |
) -> str: | |
"""Fill the placeholders in the prompt template | |
In the role_assigner agent, three placeholders are supported: | |
- ${task_description} | |
- ${former_solution} | |
- ${critic_messages} | |
- ${advice} | |
""" | |
input_arguments = { | |
"task_description": task_description, | |
"former_solution": former_solution, | |
"critic_opinions": "\n".join( | |
[ | |
f"{critic.sender_agent.role_description} said: {critic.criticism}" | |
for critic in critic_opinions | |
] | |
), | |
"advice": advice, | |
} | |
# if discussion_mode: | |
# template = Template(self.prompt_template[1]) | |
# else: | |
template = Template(self.prompt_template) | |
return template.safe_substitute(input_arguments) | |
def add_message_to_memory(self, messages: List[Message]) -> None: | |
self.memory.add_message(messages) | |
def reset(self) -> None: | |
"""Reset the agent""" | |
self.memory.reset() | |
# TODO: reset receiver | |