Spaces:
Sleeping
Sleeping
File size: 2,281 Bytes
c54d886 9b5b26a c19d193 6aae614 9b5b26a c54d886 9b5b26a 8c01ffb c54d886 8c01ffb c54d886 6aae614 e121372 c54d886 13d500a 8c01ffb c54d886 9b5b26a 8c01ffb c54d886 861422e 9b5b26a c54d886 8c01ffb 8fe992b c54d886 8c01ffb 861422e 8fe992b c54d886 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 |
from smolagents import CodeAgent, DuckDuckGoSearchTool, HfApiModel, load_tool, tool
import datetime
import requests
import pytz
import yaml
from tools.final_answer import FinalAnswerTool
from Gradio_UI import GradioUI
# Custom tools
@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:
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)}"
# DuckDuckGo Search Tool Implementation
@tool
def duckduckgo_search(query: str, max_results: int = 3) -> str:
"""A tool that performs web searches using DuckDuckGo's API.
Args:
query: The search query string
max_results: Maximum number of results to return (default 3)
"""
try:
search_results = DuckDuckGoSearchTool().search(query, max_results)
return "\n\n".join([f"{i+1}. {result['title']}\n{result['body']}\nURL: {result['href']}"
for i, result in enumerate(search_results)])
except Exception as e:
return f"Search failed: {str(e)}"
# Initialize core components
final_answer = FinalAnswerTool()
model = HfApiModel(
max_tokens=2096,
temperature=0.5,
model_id='https://wxknx1kg971u7k1n.us-east-1.aws.endpoints.huggingface.cloud',
custom_role_conversions=None,
)
# Load remote tool
image_generation_tool = load_tool("agents-course/text-to-image", trust_remote_code=True)
# Load prompt templates
with open("prompts.yaml", 'r') as stream:
prompt_templates = yaml.safe_load(stream)
# Configure agent with all tools
agent = CodeAgent(
model=model,
tools=[
final_answer,
duckduckgo_search,
image_generation_tool,
get_current_time_in_timezone
],
max_steps=6,
verbosity_level=1,
grammar=None,
planning_interval=None,
name=None,
description=None,
prompt_templates=prompt_templates
)
# Launch the interface
GradioUI(agent).launch() |