File size: 3,406 Bytes
7af0f7a
9b5b26a
 
 
c19d193
6aae614
9b5b26a
 
7af0f7a
9b5b26a
7af0f7a
 
9b5b26a
7af0f7a
9b5b26a
7af0f7a
9b5b26a
7af0f7a
9b5b26a
 
 
 
 
 
 
 
 
 
 
 
8c01ffb
7af0f7a
 
 
 
 
 
 
 
 
8c01ffb
7af0f7a
 
 
 
 
 
 
 
 
ae7a494
7af0f7a
 
ae7a494
7af0f7a
e121372
7af0f7a
 
f0bd3c0
7af0f7a
13d500a
8c01ffb
7af0f7a
861422e
 
7af0f7a
 
 
8fe992b
7af0f7a
8c01ffb
 
 
 
 
 
861422e
8fe992b
 
7af0f7a
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
9b5b26a
7af0f7a
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
from smolagents import CodeAgent, DuckDuckGoSearchTool, HfApiModel, load_tool, tool
import datetime
import requests
import pytz
import yaml
from tools.final_answer import FinalAnswerTool
from Gradio_UI import GradioUI

# Define a tool to search the internet
@tool
def search_the_internet(search_term: str) -> str:
    """A tool that can search the internet.
    Args:
        search_term: The term to search for.
    """
    return "What magic will you build?"

# Define a tool to get the current time in a specified timezone
@tool
def get_current_time_in_timezone(timezone: str) -> str:
    """A tool that fetches the current local time in a specified timezone.
    Args:
        timezone: A string representing a valid timezone (e.g., 'America/New_York').
    """
    try:
        tz = pytz.timezone(timezone)
        local_time = datetime.datetime.now(tz).strftime("%Y-%m-%d %H:%M:%S")
        return f"The current local time in {timezone} is: {local_time}"
    except Exception as e:
        return f"Error fetching time for timezone '{timezone}': {str(e)}"

# Define a tool to perform a web search
@tool
def perform_web_search(query: str) -> str:
    """A tool that performs a web search using DuckDuckGo.
    Args:
        query: The search query.
    """
    search_tool = DuckDuckGoSearchTool()
    return search_tool.run(query)

# Define a tool to generate an image from text
@tool
def generate_image_from_text(prompt: str) -> str:
    """A tool that generates an image from a text prompt.
    Args:
        prompt: The text prompt for image generation.
    """
    image_generation_tool = load_tool("agents-course/text-to-image", trust_remote_code=True)
    return image_generation_tool.run(prompt)

# Initialize the final answer tool
final_answer = FinalAnswerTool()

# Define the model
model = HfApiModel(
    max_tokens=2096,
    temperature=0.5,
    model_id='Qwen/Qwen2.5-Coder-7B-Instruct',
    custom_role_conversions=None,
)

# Load prompt templates from a YAML file
with open("prompts.yaml", 'r') as stream:
    prompt_templates = yaml.safe_load(stream)

# Define the main agent
main_agent = CodeAgent(
    model=model,
    tools=[DuckDuckGoSearchTool(), final_answer],  # Add your tools here (don't remove final answer)
    max_steps=6,
    verbosity_level=1,
    grammar=None,
    planning_interval=None,
    name=None,
    description=None,
    prompt_templates=prompt_templates
)

# Define a function to create sub-agents dynamically
def create_sub_agent(task_description: str):
    sub_agent_tools = []
    if "search" in task_description.lower():
        sub_agent_tools.append(perform_web_search)
    if "time" in task_description.lower():
        sub_agent_tools.append(get_current_time_in_timezone)
    if "image" in task_description.lower():
        sub_agent_tools.append(generate_image_from_text)

    sub_agent = CodeAgent(
        model=model,
        tools=sub_agent_tools,
        max_steps=3,
        verbosity_level=1,
        grammar=None,
        planning_interval=None,
        name="SubAgent",
        description="A dynamically created sub-agent to handle specific tasks."
    )
    return sub_agent

# Example of how the main agent can decide to create sub-agents
def decide_and_execute(task: str):
    sub_agent = create_sub_agent(task)
    result = sub_agent.run(task)
    return result

# Launch the Gradio UI with the main agent
GradioUI(main_agent).launch()