|
|
@ -799,31 +799,41 @@ class Agent:
|
|
|
|
while attempt < self.retry_attempts and not success:
|
|
|
|
while attempt < self.retry_attempts and not success:
|
|
|
|
try:
|
|
|
|
try:
|
|
|
|
if self.long_term_memory is not None:
|
|
|
|
if self.long_term_memory is not None:
|
|
|
|
logger.info(
|
|
|
|
logger.info("Querying long term memory...")
|
|
|
|
"Querying long term memory..."
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
self.memory_query(task_prompt)
|
|
|
|
self.memory_query(task_prompt)
|
|
|
|
|
|
|
|
|
|
|
|
else:
|
|
|
|
# Generate response using LLM
|
|
|
|
response_args = (
|
|
|
|
response_args = (
|
|
|
|
(task_prompt, *args)
|
|
|
|
(task_prompt, *args) if img is None else (task_prompt, img, *args)
|
|
|
|
if img is None
|
|
|
|
|
|
|
|
else (task_prompt, img, *args)
|
|
|
|
|
|
|
|
)
|
|
|
|
)
|
|
|
|
response = self.call_llm(
|
|
|
|
response = self.call_llm(*response_args, **kwargs)
|
|
|
|
*response_args, **kwargs
|
|
|
|
|
|
|
|
|
|
|
|
# Check if response is a dictionary and has 'choices' key
|
|
|
|
|
|
|
|
if isinstance(response, dict) and 'choices' in response:
|
|
|
|
|
|
|
|
response = response['choices'][0]['message']['content']
|
|
|
|
|
|
|
|
elif isinstance(response, str):
|
|
|
|
|
|
|
|
# If response is already a string, use it as is
|
|
|
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
else:
|
|
|
|
|
|
|
|
raise ValueError(
|
|
|
|
|
|
|
|
f"Unexpected response format: {type(response)}"
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Check and execute tools
|
|
|
|
|
|
|
|
if self.tools is not None:
|
|
|
|
|
|
|
|
print(f"self.tools is not None: {response}")
|
|
|
|
|
|
|
|
self.parse_and_execute_tools(response)
|
|
|
|
|
|
|
|
|
|
|
|
# Log the step metadata
|
|
|
|
# Log the step metadata
|
|
|
|
logged = self.log_step_metadata(
|
|
|
|
logged = self.log_step_metadata(
|
|
|
|
loop_count, task_prompt, response
|
|
|
|
loop_count,
|
|
|
|
|
|
|
|
task_prompt,
|
|
|
|
|
|
|
|
response
|
|
|
|
)
|
|
|
|
)
|
|
|
|
logger.info(logged)
|
|
|
|
logger.info(logged)
|
|
|
|
|
|
|
|
|
|
|
|
# Conver to a str if the response is not a str
|
|
|
|
# Convert to a str if the response is not a str
|
|
|
|
response = self.llm_output_parser(
|
|
|
|
response = self.llm_output_parser(response)
|
|
|
|
response
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Print
|
|
|
|
# Print
|
|
|
|
if self.streaming_on is True:
|
|
|
|
if self.streaming_on is True:
|
|
|
@ -833,17 +843,17 @@ class Agent:
|
|
|
|
|
|
|
|
|
|
|
|
# Add the response to the memory
|
|
|
|
# Add the response to the memory
|
|
|
|
self.short_memory.add(
|
|
|
|
self.short_memory.add(
|
|
|
|
role=self.agent_name, content=response
|
|
|
|
role=self.agent_name,
|
|
|
|
|
|
|
|
content=response
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
# Add to all responses
|
|
|
|
# Add to all responses
|
|
|
|
all_responses.append(response)
|
|
|
|
all_responses.append(response)
|
|
|
|
|
|
|
|
|
|
|
|
# TODO: Implement reliablity check
|
|
|
|
# TODO: Implement reliability check
|
|
|
|
if self.tools is not None:
|
|
|
|
if self.tools is not None:
|
|
|
|
# self.parse_function_call_and_execute(response)
|
|
|
|
# self.parse_function_call_and_execute(response)
|
|
|
|
self.parse_and_execute_tools(response)
|
|
|
|
self.parse_and_execute_tools(response)
|
|
|
|
|
|
|
|
|
|
|
|
# if self.code_interpreter is True:
|
|
|
|
# if self.code_interpreter is True:
|
|
|
|
# # Parse the code and execute
|
|
|
|
# # Parse the code and execute
|
|
|
|
# logger.info("Parsing code and executing...")
|
|
|
|
# logger.info("Parsing code and executing...")
|
|
|
@ -1846,20 +1856,21 @@ class Agent:
|
|
|
|
|
|
|
|
|
|
|
|
return response
|
|
|
|
return response
|
|
|
|
|
|
|
|
|
|
|
|
def llm_output_parser(self, response: Any) -> str:
|
|
|
|
def llm_output_parser(self, response):
|
|
|
|
"""
|
|
|
|
"""Parse the output from the LLM"""
|
|
|
|
Parses the response from the LLM (Low-Level Monitor) and returns it as a string.
|
|
|
|
try:
|
|
|
|
|
|
|
|
if isinstance(response, dict):
|
|
|
|
Args:
|
|
|
|
if 'choices' in response:
|
|
|
|
response (Any): The response from the LLM.
|
|
|
|
return response['choices'][0]['message']['content']
|
|
|
|
|
|
|
|
else:
|
|
|
|
Returns:
|
|
|
|
return json.dumps(response) # Convert dict to string
|
|
|
|
str: The parsed response as a string.
|
|
|
|
elif isinstance(response, str):
|
|
|
|
"""
|
|
|
|
|
|
|
|
if response is not str:
|
|
|
|
|
|
|
|
response = str(response)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return response
|
|
|
|
return response
|
|
|
|
|
|
|
|
else:
|
|
|
|
|
|
|
|
return str(response) # Convert any other type to string
|
|
|
|
|
|
|
|
except Exception as e:
|
|
|
|
|
|
|
|
logger.error(f"Error parsing LLM output: {e}")
|
|
|
|
|
|
|
|
return str(response) # Return string representation as fallback
|
|
|
|
|
|
|
|
|
|
|
|
def log_step_metadata(
|
|
|
|
def log_step_metadata(
|
|
|
|
self, loop: int, task: str, response: str
|
|
|
|
self, loop: int, task: str, response: str
|
|
|
|