Spaces:
Sleeping
Sleeping
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() |