|
|
@ -61,6 +61,8 @@ from dataclasses import asdict
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Utils
|
|
|
|
# Utils
|
|
|
|
# Custom stopping condition
|
|
|
|
# Custom stopping condition
|
|
|
|
def stop_when_repeats(response: str) -> bool:
|
|
|
|
def stop_when_repeats(response: str) -> bool:
|
|
|
@ -812,6 +814,9 @@ class Agent:
|
|
|
|
)
|
|
|
|
)
|
|
|
|
response = self.call_llm(*response_args, **kwargs)
|
|
|
|
response = self.call_llm(*response_args, **kwargs)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Log step metadata
|
|
|
|
|
|
|
|
step_meta = self.log_step_metadata(loop_count, task_prompt, response)
|
|
|
|
|
|
|
|
|
|
|
|
# Check if response is a dictionary and has 'choices' key
|
|
|
|
# Check if response is a dictionary and has 'choices' key
|
|
|
|
if isinstance(response, dict) and 'choices' in response:
|
|
|
|
if isinstance(response, dict) and 'choices' in response:
|
|
|
|
response = response['choices'][0]['message']['content']
|
|
|
|
response = response['choices'][0]['message']['content']
|
|
|
@ -825,9 +830,7 @@ class Agent:
|
|
|
|
|
|
|
|
|
|
|
|
# Check and execute tools
|
|
|
|
# Check and execute tools
|
|
|
|
if self.tools is not None:
|
|
|
|
if self.tools is not None:
|
|
|
|
print(f"self.tools is not None: {response}")
|
|
|
|
|
|
|
|
tool_result = self.parse_and_execute_tools(response)
|
|
|
|
tool_result = self.parse_and_execute_tools(response)
|
|
|
|
self.parse_and_execute_tools(response)
|
|
|
|
|
|
|
|
if tool_result:
|
|
|
|
if tool_result:
|
|
|
|
self.update_tool_usage(
|
|
|
|
self.update_tool_usage(
|
|
|
|
step_meta["step_id"],
|
|
|
|
step_meta["step_id"],
|
|
|
@ -851,9 +854,6 @@ class Agent:
|
|
|
|
# Convert 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)
|
|
|
|
response = self.llm_output_parser(response)
|
|
|
|
|
|
|
|
|
|
|
|
# Log step metadata
|
|
|
|
|
|
|
|
step_meta = self.log_step_metadata(loop_count, task_prompt, response)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Print
|
|
|
|
# Print
|
|
|
|
if self.streaming_on is True:
|
|
|
|
if self.streaming_on is True:
|
|
|
|
self.stream_response(response)
|
|
|
|
self.stream_response(response)
|
|
|
@ -1003,6 +1003,7 @@ class Agent:
|
|
|
|
else:
|
|
|
|
else:
|
|
|
|
return concat_strings(all_responses)
|
|
|
|
return concat_strings(all_responses)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
except Exception as error:
|
|
|
|
except Exception as error:
|
|
|
|
logger.info(
|
|
|
|
logger.info(
|
|
|
|
f"Error running agent: {error} optimize your input parameters"
|
|
|
|
f"Error running agent: {error} optimize your input parameters"
|
|
|
@ -1948,6 +1949,7 @@ class Agent:
|
|
|
|
# Add step to agent output tracking
|
|
|
|
# Add step to agent output tracking
|
|
|
|
return self.step_pool.append(step_log)
|
|
|
|
return self.step_pool.append(step_log)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def update_tool_usage(self, step_id: str, tool_name: str, tool_args: dict, tool_response: Any):
|
|
|
|
def update_tool_usage(self, step_id: str, tool_name: str, tool_args: dict, tool_response: Any):
|
|
|
|
"""Update tool usage information for a specific step."""
|
|
|
|
"""Update tool usage information for a specific step."""
|
|
|
|
for step in self.agent_output.steps:
|
|
|
|
for step in self.agent_output.steps:
|
|
|
|