D-r-e commited on
Commit
4c960db
·
verified ·
1 Parent(s): ae7a494

My first agent

Browse files
Files changed (1) hide show
  1. app.py +64 -39
app.py CHANGED
@@ -1,61 +1,87 @@
1
- from smolagents import CodeAgent,DuckDuckGoSearchTool, HfApiModel,load_tool,tool
2
- import datetime
 
 
 
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
- # Below is an example of a tool that does nothing. Amaze us with your creativity !
11
- @tool
12
- def my_custom_tool(arg1:str, arg2:int)-> str: #it's import to specify the return type
13
- #Keep this format for the description / args / args description but feel free to modify the tool
14
- """A tool that does nothing yet
15
- Args:
16
- arg1: the first argument
17
- arg2: the second argument
18
- """
19
- return "What magic will you build ?"
 
 
 
20
 
21
  @tool
22
- def get_current_time_in_timezone(timezone: str) -> str:
23
- """A tool that fetches the current local time in a specified timezone.
 
24
  Args:
25
- timezone: A string representing a valid timezone (e.g., 'America/New_York').
 
 
 
26
  """
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
27
  try:
28
- # Create timezone object
29
- tz = pytz.timezone(timezone)
30
- # Get current time in that timezone
31
- local_time = datetime.datetime.now(tz).strftime("%Y-%m-%d %H:%M:%S")
32
- return f"The current local time in {timezone} is: {local_time}"
 
 
 
 
 
 
 
 
33
  except Exception as e:
34
- return f"Error fetching time for timezone '{timezone}': {str(e)}"
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.5,
45
- model_id='Qwen/Qwen2.5-Coder-32B-Instruct',# it is possible that this model may be overloaded
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], ## add your tools here (don't remove 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()