File size: 3,828 Bytes
9b5b26a
d79187f
9b5b26a
 
 
c19d193
6aae614
8fe992b
9b5b26a
 
5df72d6
d79187f
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
9b5b26a
 
d79187f
 
 
 
9b5b26a
d79187f
 
 
9b5b26a
d79187f
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
8c01ffb
 
6aae614
e121372
bf6d34c
 
9a8c112
fe328e0
13d500a
8c01ffb
 
9b5b26a
 
8c01ffb
861422e
 
9b5b26a
8c01ffb
8fe992b
d2f6a24
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
101
102
103
104
from smolagents import CodeAgent,DuckDuckGoSearchTool, HfApiModel,load_tool,tool
from typing import Union
import datetime
import requests
import pytz
import yaml
from tools.final_answer import FinalAnswerTool

from Gradio_UI import GradioUI

# Below is an example of a tool that does nothing. Amaze us with your creativity !
# @tool
# def my_cutom_tool(arg1:str, 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 tool that does nothing yet 
#     Args:
#         arg1: the first argument
#         arg2: the second argument
#     """
#     return "What magic will you build ?"

# @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)}"

@tool
def unit_to_unit(unit_value: Union[int, float], input_unit_type: str, output_unit_type: str) -> str:
    """
    A tool that converts the incoming unit to a given target unit\n
    Supports length, weight and temperature conversions
    Args:
        unit_value: The numeric value to be adjusted.
        input_unit_type: The input unit to convert from.
        output_unit_type: The target unit to convert to.
    """
    conversion_dict = {
        # Length conversions
        ("km", "mi"): lambda x: x * 0.621371,    # Kilometers to miles
        ("mi", "km"): lambda x: x * 1.60934,     # Miles to kilometers
        ("m", "ft"): lambda x: x * 3.28084,      # Meters to feet
        ("ft", "m"): lambda x: x * 0.3048,       # Feet to meters
        ("cm", "in"): lambda x: x * 0.393701,    # Centimeters to inches
        ("in", "cm"): lambda x: x * 2.54,        # Inches to centimeters

        # Weight conversions
        ("kg", "lbs"): lambda x: x * 2.20462,    # Kilograms to pounds
        ("lbs", "kg"): lambda x: x * 0.453592,   # Pounds to kilograms
        ("g", "oz"): lambda x: x * 0.035274,     # Grams to ounces
        ("oz", "g"): lambda x: x * 28.3495,      # Ounces to grams

        # Temperature conversions
        ("c", "f"): lambda x: (x * 9/5) + 32,    # Celsius to Fahrenheit
        ("f", "c"): lambda x: (x - 32) * 5/9,    # Fahrenheit to Celsius
    }

    pairing = (input_unit_type, output_unit_type)

    if pairing in conversion_dict:
        scale = conversion_dict[pairing]
        return f"{unit_value}{input_unit_type} is equal to {scale(unit_value): .2f}{output_unit_type}"
    else:
        return f"Conversion between {input_unit_type} and {output_unit_type} is not supported"


final_answer = FinalAnswerTool()
model = HfApiModel(
max_tokens=2096,
temperature=0.5,
model_id='https://wxknx1kg971u7k1n.us-east-1.aws.endpoints.huggingface.cloud',# 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], ## 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()