sulibor's picture
testing new tools
949f50d
from smolagents import CodeAgent,DuckDuckGoSearchTool, HfApiModel,load_tool,tool
import datetime
import requests
import pytz
import yaml
import json
from tools.final_answer import FinalAnswerTool
from tools.visit_webpage import VisitWebpageTool
from tools.web_search import DuckDuckGoSearchTool as WebSearchTool
from Gradio_UI import GradioUI
@tool
def get_wikipedia_summary(topic: str) -> str:
"""Fetches a short summary from Wikipedia for a given topic.
Args:
topic: The topic to search for on Wikipedia (e.g., 'Python programming language').
"""
try:
url = "https://en.wikipedia.org/api/rest_v1/page/summary/" + topic.replace(" ", "_")
response = requests.get(url, timeout=15)
if response.status_code == 200:
data = response.json()
title = data.get("title", topic)
extract = data.get("extract", "No summary available.")
page_url = data.get("content_urls", {}).get("desktop", {}).get("page", "")
return f"**{title}**\n\n{extract}\n\nRead more: {page_url}"
elif response.status_code == 404:
return f"No Wikipedia article found for '{topic}'. Try a different search term."
else:
return f"Error fetching Wikipedia summary (HTTP {response.status_code})."
except Exception as e:
return f"Error fetching Wikipedia summary for '{topic}': {str(e)}"
@tool
def get_random_fun_fact() -> str:
"""Fetches a random fun/useless fact from the uselessfacts API. No arguments needed.
"""
try:
response = requests.get("https://uselessfacts.jsph.pl/api/v2/facts/random", timeout=10)
if response.status_code == 200:
data = response.json()
return f"🎲 Fun fact: {data.get('text', 'No fact available.')}"
return "Could not fetch a fun fact right now. Try again later."
except Exception as e:
return f"Error fetching fun fact: {str(e)}"
@tool
def convert_units(value: float, from_unit: str, to_unit: str) -> str:
"""Converts a numeric value between common units of measurement.
Supports length (km, miles, m, ft, in, cm), weight (kg, lbs, g, oz),
and temperature (celsius, fahrenheit, kelvin).
Args:
value: The numeric value to convert.
from_unit: The unit to convert from (e.g., 'km', 'lbs', 'celsius').
to_unit: The unit to convert to (e.g., 'miles', 'kg', 'fahrenheit').
"""
conversions_to_base = {
# Length → meters
"km": ("length", lambda v: v * 1000),
"m": ("length", lambda v: v),
"cm": ("length", lambda v: v / 100),
"miles": ("length", lambda v: v * 1609.344),
"ft": ("length", lambda v: v * 0.3048),
"in": ("length", lambda v: v * 0.0254),
# Weight → grams
"kg": ("weight", lambda v: v * 1000),
"g": ("weight", lambda v: v),
"lbs": ("weight", lambda v: v * 453.592),
"oz": ("weight", lambda v: v * 28.3495),
# Temperature → celsius
"celsius": ("temp", lambda v: v),
"fahrenheit": ("temp", lambda v: (v - 32) * 5 / 9),
"kelvin": ("temp", lambda v: v - 273.15),
}
conversions_from_base = {
"km": lambda v: v / 1000, "m": lambda v: v, "cm": lambda v: v * 100,
"miles": lambda v: v / 1609.344, "ft": lambda v: v / 0.3048, "in": lambda v: v / 0.0254,
"kg": lambda v: v / 1000, "g": lambda v: v, "lbs": lambda v: v / 453.592, "oz": lambda v: v / 28.3495,
"celsius": lambda v: v, "fahrenheit": lambda v: v * 9 / 5 + 32, "kelvin": lambda v: v + 273.15,
}
fu = from_unit.lower().strip()
tu = to_unit.lower().strip()
if fu not in conversions_to_base or tu not in conversions_from_base:
return f"Unsupported unit(s): '{from_unit}' or '{to_unit}'. Supported: {list(conversions_to_base.keys())}"
cat_from, to_base = conversions_to_base[fu]
cat_to, _ = conversions_to_base[tu]
if cat_from != cat_to:
return f"Cannot convert between '{from_unit}' ({cat_from}) and '{to_unit}' ({cat_to}). Units must be in the same category."
base_value = to_base(value)
result = conversions_from_base[tu](base_value)
return f"{value} {from_unit} = {result:.4f} {to_unit}"
@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 string representing a valid timezone (e.g., 'America/New_York').
"""
try:
# Create timezone object
tz = pytz.timezone(timezone)
# Get current time in that 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)}"
final_answer = FinalAnswerTool()
web_search = WebSearchTool()
visit_webpage = VisitWebpageTool()
# 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:
# model_id='https://pflgm2locj2t89co.us-east-1.aws.endpoints.huggingface.cloud'
model = HfApiModel(
max_tokens=2096,
temperature=0.5,
model_id='Qwen/Qwen2.5-Coder-32B-Instruct',# it is possible that this model may be overloaded
custom_role_conversions=None,
)
# Import tool from Hub
image_generation_tool = load_tool("agents-course/text-to-image", trust_remote_code=True)
with open("prompts.yaml", 'r') as stream:
prompt_templates = yaml.safe_load(stream)
agent = CodeAgent(
model=model,
tools=[
final_answer,
web_search,
visit_webpage,
get_current_time_in_timezone,
get_wikipedia_summary,
get_random_fun_fact,
convert_units,
image_generation_tool,
],
max_steps=6,
verbosity_level=1,
grammar=None,
planning_interval=None,
name=None,
description=None,
prompt_templates=prompt_templates
)
GradioUI(agent).launch()