File size: 4,206 Bytes
59111ae
9b5b26a
 
 
c19d193
6aae614
9b5b26a
 
 
 
59111ae
 
9b5b26a
59111ae
9b5b26a
 
 
 
 
 
 
8c01ffb
6d8e585
179d75d
6d8e585
e12f601
b329fbc
5fa8814
6d8e585
e12f601
6d8e585
b329fbc
 
 
 
 
 
 
2ae321f
b329fbc
179d75d
5fa8814
6d8e585
b329fbc
 
 
 
 
e12f601
b329fbc
179d75d
e12f601
 
b329fbc
 
e12f601
 
b329fbc
 
 
 
 
 
 
 
e12f601
 
 
179d75d
e12f601
179d75d
e12f601
179d75d
 
 
 
5fa8814
6d8e585
179d75d
e12f601
179d75d
 
59111ae
179d75d
 
 
 
 
5fa8814
179d75d
59111ae
6d8e585
59111ae
6aae614
ae7a494
59111ae
e121372
59111ae
 
 
 
13d500a
8c01ffb
59111ae
861422e
 
59111ae
 
8c01ffb
8fe992b
59111ae
8c01ffb
 
 
 
 
 
861422e
8fe992b
 
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
114
115
116
117
118
119
120
121
from smolagents import CodeAgent, 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 get_current_time_in_timezone(timezone: str) -> str:
    """
    A tool that fetches the current local time in a specified timezone.
    Args:
        timezone: A valid timezone string (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)}"

@tool
def get_nba_matches() -> str:
    """
    A tool that retrieves upcoming NBA matches using TheRundown API.
    (Assumes that sport-id 4 corresponds to the NBA and uses the "openers" endpoint.)
    
    Returns:
        A human-readable string listing the upcoming NBA matches.
    """
    import requests
    import datetime

    # Get today's date in YYYY-MM-DD format (or adjust to the desired event date)
    today = datetime.date.today().strftime("%Y-%m-%d")
    # Construct the URL using the required parameters.
    # Based on the API info, the URL should include the sport-id (here 4 for NBA) and the event date.
    url = f"https://api.apilayer.com/therundown/sports/4/openers/{today}?offset=0&include=scores"
    
    headers = {
        "apikey": "7k4hKSUeWkbigKxZiNV5CQ8RSlEd72Cj"
    }
    # Define query parameters if needed; here on fixe offset à 0 et on demande par exemple les scores (optionnel)
    params = {
        "offset": "0",
        "include": "scores"
    }
    
    response = requests.get(url, headers=headers, params=params)
    if response.status_code == 200:
        data = response.json()
        matches = []
        # Ajustez le parsing en fonction de la structure exacte de la réponse.
        # Par exemple, nous supposons que la réponse contient une clé "events" qui liste les matchs.
        for event in data.get("events", []):
            start_time = event.get("start_time", "Unknown time")
            # Supposons que l'information sur les équipes se trouve dans une liste "teams" avec un attribut "name"
            teams = event.get("teams", [])
            if len(teams) >= 2:
                home_team = teams[0].get("name", "Home team N/A")
                away_team = teams[1].get("name", "Away team N/A")
            else:
                home_team = "Home team N/A"
                away_team = "Away team N/A"
            matches.append(f"{start_time}: {home_team} vs {away_team}")
        if matches:
            return "\n".join(matches)
        else:
            return "No NBA matches found."
    else:
        return f"Error retrieving NBA matches: {response.status_code}"

@tool
def predict_nba_match(match_info: str) -> str:
    """
    A tool that generates a prediction for an NBA match.
    
    Args:
        match_info: A string containing match details in the format "TeamA vs TeamB".
    
    Returns:
        A string with the prediction (e.g., "The prediction is that TeamA will win.").
    """
    import random
    teams = match_info.split(" vs ")
    if len(teams) == 2:
        prediction = random.choice(teams)
        return f"The prediction is that {prediction} will win."
    else:
        return "Invalid match format. Please provide details in the format 'TeamA vs TeamB'."

# Instantiate the final_answer tool.
final_answer = FinalAnswerTool()

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

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

# Initialize the agent with all necessary tools.
agent = CodeAgent(
    model=model,
    tools=[final_answer, get_current_time_in_timezone, get_nba_matches, predict_nba_match],
    max_steps=6,
    verbosity_level=1,
    grammar=None,
    planning_interval=None,
    name=None,
    description=None,
    prompt_templates=prompt_templates
)

GradioUI(agent).launch()