Spaces:
Sleeping
Sleeping
My first agent
Browse files
app.py
CHANGED
@@ -1,61 +1,87 @@
|
|
1 |
-
|
2 |
-
import
|
|
|
|
|
|
|
3 |
import requests
|
4 |
-
import pytz
|
5 |
import yaml
|
6 |
-
from tools.final_answer import FinalAnswerTool
|
7 |
|
|
|
|
|
8 |
from Gradio_UI import GradioUI
|
9 |
|
10 |
-
|
11 |
-
|
12 |
-
|
13 |
-
|
14 |
-
|
15 |
-
|
16 |
-
|
17 |
-
|
18 |
-
|
19 |
-
|
|
|
|
|
|
|
20 |
|
21 |
@tool
|
22 |
-
def
|
23 |
-
"""
|
|
|
24 |
Args:
|
25 |
-
|
|
|
|
|
|
|
26 |
"""
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
27 |
try:
|
28 |
-
|
29 |
-
|
30 |
-
|
31 |
-
|
32 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
33 |
except Exception as e:
|
34 |
-
return f"
|
35 |
-
|
36 |
|
37 |
final_answer = FinalAnswerTool()
|
38 |
|
39 |
-
# 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:
|
40 |
-
# model_id='https://pflgm2locj2t89co.us-east-1.aws.endpoints.huggingface.cloud'
|
41 |
-
|
42 |
model = HfApiModel(
|
43 |
-
max_tokens=2096,
|
44 |
-
temperature=0.
|
45 |
-
model_id='Qwen/Qwen2.5-Coder-32B-Instruct'
|
46 |
-
custom_role_conversions=None,
|
47 |
)
|
48 |
|
49 |
-
|
50 |
-
# Import tool from Hub
|
51 |
-
image_generation_tool = load_tool("agents-course/text-to-image", trust_remote_code=True)
|
52 |
-
|
53 |
with open("prompts.yaml", 'r') as stream:
|
54 |
prompt_templates = yaml.safe_load(stream)
|
55 |
-
|
56 |
agent = CodeAgent(
|
57 |
model=model,
|
58 |
-
tools=[final_answer],
|
59 |
max_steps=6,
|
60 |
verbosity_level=1,
|
61 |
grammar=None,
|
@@ -65,5 +91,4 @@ agent = CodeAgent(
|
|
65 |
prompt_templates=prompt_templates
|
66 |
)
|
67 |
|
68 |
-
|
69 |
-
GradioUI(agent).launch()
|
|
|
1 |
+
import os
|
2 |
+
import urllib.request
|
3 |
+
import zipfile
|
4 |
+
from pathlib import Path
|
5 |
+
import pandas as pd
|
6 |
import requests
|
|
|
7 |
import yaml
|
|
|
8 |
|
9 |
+
from smolagents import CodeAgent, HfApiModel, load_tool, tool
|
10 |
+
from tools.final_answer import FinalAnswerTool
|
11 |
from Gradio_UI import GradioUI
|
12 |
|
13 |
+
def download_and_unzip(download_folder) -> pd.DataFrame:
|
14 |
+
os.makedirs(download_folder, exist_ok=True)
|
15 |
+
csv_path = Path(download_folder) / "worldcities.csv"
|
16 |
+
if csv_path.exists():
|
17 |
+
return pd.read_csv(csv_path, index_col=False)
|
18 |
+
zip_filename = "simplemaps_worldcities_basicv1.77.zip"
|
19 |
+
zip_filepath = os.path.join(download_folder, zip_filename)
|
20 |
+
if not os.path.exists(zip_filepath):
|
21 |
+
url = "https://simplemaps.com/static/data/world-cities/basic/simplemaps_worldcities_basicv1.77.zip"
|
22 |
+
urllib.request.urlretrieve(url, zip_filepath)
|
23 |
+
with zipfile.ZipFile(zip_filepath, 'r') as zip_ref:
|
24 |
+
zip_ref.extractall(download_folder)
|
25 |
+
return pd.read_csv(csv_path, index_col=False)
|
26 |
|
27 |
@tool
|
28 |
+
def get_weather_for_city(city: str, country: str) -> str:
|
29 |
+
"""Searches for the city in the world cities dataset, obtains its coordinates,
|
30 |
+
and fetches current weather from the Open-Meteo API.
|
31 |
Args:
|
32 |
+
city: Name of the city (case insensitive, matches 'city_ascii' in the CSV).
|
33 |
+
country: Name of the country (case insensitive).
|
34 |
+
Returns:
|
35 |
+
A string containing the city's coordinates and current weather details.
|
36 |
"""
|
37 |
+
df = download_and_unzip("downloads")
|
38 |
+
matches = df[(df['city_ascii'].str.lower() == city.lower()) & (df['country'].str.lower() == country.lower())]
|
39 |
+
if matches.empty:
|
40 |
+
return f"No location found for {city}, {country}."
|
41 |
+
|
42 |
+
row = matches.iloc[0]
|
43 |
+
lat = float(row['lat'])
|
44 |
+
lng = float(row['lng'])
|
45 |
+
|
46 |
+
url = "https://api.open-meteo.com/v1/forecast"
|
47 |
+
params = {
|
48 |
+
"latitude": lat,
|
49 |
+
"longitude": lng,
|
50 |
+
"current_weather": "true"
|
51 |
+
}
|
52 |
+
|
53 |
try:
|
54 |
+
response = requests.get(url, params=params, timeout=10)
|
55 |
+
if response.status_code != 200:
|
56 |
+
return f"Error fetching weather data: {response.status_code}."
|
57 |
+
data = response.json()
|
58 |
+
if "current_weather" not in data:
|
59 |
+
return "Weather data not available."
|
60 |
+
current = data["current_weather"]
|
61 |
+
temperature = current.get("temperature")
|
62 |
+
windspeed = current.get("windspeed")
|
63 |
+
winddirection = current.get("winddirection")
|
64 |
+
time_str = current.get("time")
|
65 |
+
return (f"Current weather in {row['city_ascii']}, {row['country']} (lat: {lat}, lng: {lng}):\n"
|
66 |
+
f"Temperature: {temperature}°C, Wind Speed: {windspeed} km/h, Wind Direction: {winddirection}° at {time_str}.")
|
67 |
except Exception as e:
|
68 |
+
return f"An error occurred while fetching weather data: {str(e)}"
|
|
|
69 |
|
70 |
final_answer = FinalAnswerTool()
|
71 |
|
|
|
|
|
|
|
72 |
model = HfApiModel(
|
73 |
+
max_tokens=2096,
|
74 |
+
temperature=0.4,
|
75 |
+
model_id='Qwen/Qwen2.5-Coder-32B-Instruct',
|
76 |
+
custom_role_conversions=None,
|
77 |
)
|
78 |
|
|
|
|
|
|
|
|
|
79 |
with open("prompts.yaml", 'r') as stream:
|
80 |
prompt_templates = yaml.safe_load(stream)
|
81 |
+
|
82 |
agent = CodeAgent(
|
83 |
model=model,
|
84 |
+
tools=[final_answer, get_weather_for_city],
|
85 |
max_steps=6,
|
86 |
verbosity_level=1,
|
87 |
grammar=None,
|
|
|
91 |
prompt_templates=prompt_templates
|
92 |
)
|
93 |
|
94 |
+
GradioUI(agent).launch()
|
|