File size: 4,201 Bytes
9b5b26a
 
 
 
c19d193
6aae614
8fe992b
9b5b26a
 
 
9133642
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
9b5b26a
 
 
 
 
 
 
 
 
 
 
 
 
 
8c01ffb
 
6aae614
ae7a494
 
 
 
e121372
bf6d34c
 
6d607dd
 
fe328e0
13d500a
8c01ffb
 
9b5b26a
 
8c01ffb
861422e
 
9b5b26a
8c01ffb
8fe992b
e04b76f
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
105
106
107
108
109
110
111
112
113
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


@tool
def calculate_time_lag(timezone1:str, timezone2:int)-> str: #it's import to specify the return type
    """
    A tool that calculates the time lag between two timezones based on their current local times.
   Args:
        timezone1: A string representing the first timezone (e.g., 'Asia/Seoul').
        timezone2: A string representing the second timezone (e.g., 'America/New_York').
    Returns:
        A string describing the time difference in hours and minutes.
    """
    try:
        now_utc = datetime.datetime.now(datetime.timezone.utc)

        tz1 = pytz.timezone(timezone1)
        tz1_local = now_utc.astimezone(tz1)

        tz2 = pytz.timezone(timezone2)
        tz2_local = now_utc.astimezone(tz2)

        # 시간 차이 (timezone1 기준에서 얼마나 차이 나는지)
        time_diff = tz1_local - tz2_local

        # 시/분 단위로 계산
        diff_hours = time_diff.total_seconds() // 3600
        diff_minutes = (time_diff.total_seconds() % 3600) // 60

        # 절댓값 계산
        abs_hours = abs(diff_hours)
        abs_minutes = abs(diff_minutes)

        if time_diff.total_seconds() == 0:
            # 완전히 동일할 수도 있음
            return (f"현재 {timezone1}와(과) {timezone2}는 시차가 없습니다. "
                    f"(동일한 시각)")
        elif time_diff.total_seconds() > 0:
            # time_diff > 0 이면 timezone2가 timezone1보다 느림(뒤쳐짐)
            if abs_minutes == 0:
                return (f"{timezone2}{timezone1} 기준으로 "
                        f"{int(abs_hours)}시간 늦습니다.")
            else:
                return (f"{timezone2}{timezone1} 기준으로 "
                        f"{int(abs_hours)}시간 {int(abs_minutes)}분 늦습니다.")
        else:
            # time_diff < 0 이면 timezone2가 timezone1보다 빠름
            if abs_minutes == 0:
                return (f"{timezone2}{timezone1} 기준으로 "
                        f"{int(abs_hours)}시간 빠릅니다.")
            else:
                return (f"{timezone2}{timezone1} 기준으로 "
                        f"{int(abs_hours)}시간 {int(abs_minutes)}분 빠릅니다.")
    except Exception as e:
        return f"Error calculating time difference: {str(e)}"

@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()

# If the agent does not answer, the model is overloaded, please use another model or the following Hugging Face Endpoint that also contains qwen2.5 coder:
# model_id='https://pflgm2locj2t89co.us-east-1.aws.endpoints.huggingface.cloud' 

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
model_id='https://pflgm2locj2t89co.us-east-1.aws.endpoints.huggingface.cloud' ,
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=[calculate_time_lag, 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()