File size: 3,694 Bytes
9b5b26a
 
 
 
c19d193
6aae614
a9563eb
9b5b26a
 
d994115
29a01fd
 
 
 
 
 
 
 
 
 
 
d994115
29a01fd
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
5df72d6
9b5b26a
eeb8f36
9b5b26a
cf78d15
9b5b26a
eeb8f36
 
9b5b26a
cf78d15
9b5b26a
 
 
 
 
 
 
 
 
 
 
 
 
 
 
8c01ffb
 
6aae614
e121372
bf6d34c
 
6431356
fe328e0
13d500a
8c01ffb
 
9b5b26a
 
8c01ffb
861422e
 
9b5b26a
8c01ffb
8fe992b
cf78d15
8c01ffb
 
 
 
 
 
861422e
8fe992b
 
9b5b26a
8c01ffb
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
from smolagents import CodeAgent,DuckDuckGoSearchTool, HfApiModel,load_tool,tool
import datetime
import requests
import pytz
import yaml
from tools.final_answer import FinalAnswerTool
from organisation_tools import PlanningTool
from Gradio_UI import GradioUI

#now make the tool with all the methods and attributes with everything from organisation_tools.py
@tool
class PlanningToolWrapper:
    """A tool for managing and retrieving activities from a planning tool.
    Args:
        filename: The name of the JSON file to store the planning data.
        activity: The activity to add.
        timestamp: The timestamp for the activity.
        date: The date to filter activities by.
        month: The month to filter activities by.
        year: The year to filter activities by.
    """
    def __init__(self, filename: str = "planning_data.json") -> None:
        self.planning_tool = PlanningTool(filename)

    def add_activity(self, activity: str, timestamp: str) -> str:
        """Adds an activity to the planning tool."""
        return self.planning_tool.add_activity(activity, timestamp)

    def get_activities(self) -> str:
        """Retrieves all activities from the planning tool."""
        return self.planning_tool.get_activities()

    def get_activities_by_date(self, date: str) -> str:
        """Retrieves activities by date from the planning tool."""
        return self.planning_tool.get_activities_by_date(date)

    def get_activities_by_month(self, month: str) -> str:
        """Retrieves activities by month from the planning tool."""
        return self.planning_tool.get_activities_by_month(month)

    def get_activities_by_year(self, year: str) -> str:
        """Retrieves activities by year from the planning tool."""
        return self.planning_tool.get_activities_by_year(year)

# Below is an example of a tool that does nothing. Amaze us with your creativity !
@tool
def simple_calculator(arg1:int, arg2:int)-> str: #it's import to specify the return type
    #Keep this format for the description / args / args description but feel free to modify the tool
    """A simple calculator tool that adds two numbers. 
    Args:
        arg1: An int representing the first number.
        arg2: An int representing the second number.
    """
    return f"The sum of {arg1} and {arg2} is {arg1+arg2}"

@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:
        # Create timezone object
        tz = pytz.timezone(timezone)
        # Get current time in that 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)}"


final_answer = FinalAnswerTool()
model = HfApiModel(
max_tokens=2096,
temperature=0.5,
model_id='Qwen/Qwen2.5-Coder-32B-Instruct',# it is possible that this model may be overloaded
custom_role_conversions=None,
)


# Import tool from Hub
image_generation_tool = load_tool("agents-course/text-to-image", trust_remote_code=True)

with open("prompts.yaml", 'r') as stream:
    prompt_templates = yaml.safe_load(stream)
    
agent = CodeAgent(
    model=model,
    tools=[final_answer,simple_calculator], ## 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
)


GradioUI(agent).launch()