71 lines
2.4 KiB
Python
71 lines
2.4 KiB
Python
|
from typing import Optional
|
||
|
import requests
|
||
|
|
||
|
from smolagents.agents import ToolCallingAgent
|
||
|
from smolagents import CodeAgent, HfApiModel, tool
|
||
|
from huggingface_hub import login
|
||
|
from smolagents import LiteLLMModel
|
||
|
|
||
|
from dotenv import load_dotenv
|
||
|
import os
|
||
|
|
||
|
# load .env file
|
||
|
load_dotenv()
|
||
|
|
||
|
api_key = os.environ.get('API_KEY')
|
||
|
weather_api = os.environ.get('WEATHER_API')
|
||
|
|
||
|
#print(api_key)
|
||
|
login(api_key)
|
||
|
|
||
|
|
||
|
# Select LLM engine to use!
|
||
|
model = HfApiModel()
|
||
|
# model = LiteLLMModel(
|
||
|
# model_id="ollama_chat/llama3.1",
|
||
|
# api_base="http://localhost:11434", # replace with remote open-ai compatible server if necessary
|
||
|
# #api_key="your-api-key", # replace with API key if necessary
|
||
|
# #num_ctx=8192, # ollama default is 2048 which will often fail horribly. 8192 works for easy tasks, more is better. Check https://huggingface.co/spaces/NyxKrage/LLM-Model-VRAM-Calculator to calculate how much VRAM this will need for the selected model.
|
||
|
# )
|
||
|
|
||
|
|
||
|
@tool
|
||
|
def get_weather(location: str, celsius: Optional[bool] = False) -> str:
|
||
|
"""
|
||
|
Get the current weather at the given location using the WeatherStack API.
|
||
|
|
||
|
Args:
|
||
|
location: The location (city name).
|
||
|
celsius: Whether to return the temperature in Celsius (default is False, which returns Fahrenheit).
|
||
|
|
||
|
Returns:
|
||
|
A string describing the current weather at the location.
|
||
|
"""
|
||
|
api_key = weather_api # Replace with your API key from https://weatherstack.com/
|
||
|
units = "m" if celsius else "f" # 'm' for Celsius, 'f' for Fahrenheit
|
||
|
|
||
|
url = f"http://api.weatherstack.com/current?access_key={api_key}&query={location}&units={units}"
|
||
|
|
||
|
try:
|
||
|
response = requests.get(url)
|
||
|
response.raise_for_status() # Raise an exception for HTTP errors
|
||
|
|
||
|
data = response.json()
|
||
|
|
||
|
if data.get("error"): # Check if there's an error in the response
|
||
|
return f"Error: {data['error'].get('info', 'Unable to fetch weather data.')}"
|
||
|
|
||
|
weather = data["current"]["weather_descriptions"][0]
|
||
|
temp = data["current"]["temperature"]
|
||
|
temp_unit = "°C" if celsius else "°F"
|
||
|
|
||
|
return f"The current weather in {location} is {weather} with a temperature of {temp} {temp_unit}."
|
||
|
|
||
|
except requests.exceptions.RequestException as e:
|
||
|
return f"Error fetching weather data: {str(e)}"
|
||
|
|
||
|
|
||
|
agent = ToolCallingAgent(tools=[get_weather], model=model)
|
||
|
# agent = CodeAgent(tools=[get_weather], model=model)
|
||
|
|
||
|
agent.run("What is the weather in New York?")
|