Spaces:
Sleeping
Sleeping
File size: 2,178 Bytes
9b5b26a c19d193 c81f949 11f042a 05ffcef c81f949 05ffcef c81f949 05ffcef 9b5b26a 05ffcef 9b5b26a 8c01ffb 05ffcef 8c01ffb 05ffcef 6aae614 ae7a494 9b5b26a 8c01ffb 7ac565c 060cc71 7ac565c 05ffcef 861422e 05ffcef 8c01ffb 8fe992b 05ffcef 11f042a 05ffcef 8c01ffb 861422e 8fe992b 05ffcef 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 | import datetime
import yaml
import os
from smolagents import CodeAgent, LiteLLMModel, DuckDuckGoSearchTool, load_tool, tool
from tools.final_answer import FinalAnswerTool
from Gradio_UI import GradioUI
import pytz
# It's crucial to set your GEMINI_API_KEY in your environment secrets.
# The code will fail if the key is not found.
if "GEMINI_API_KEY" not in os.environ:
raise ValueError("GEMINI_API_KEY environment variable not set! Please add it to your secrets.")
# --- Tool Definitions ---
@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', 'Europe/Berlin').
"""
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)}"
# --- Main Application Setup ---
# Initialize the mandatory final answer tool
final_answer = FinalAnswerTool()
# Import tool from Hub
image_generation_tool = load_tool("agents-course/text-to-image", trust_remote_code=True)
# Initialize the pre-built DuckDuckGo search tool
web_search_tool = DuckDuckGoSearchTool()
# Define the model using the LiteLLMModel wrapper for Gemini
# This is the correct way to integrate external APIs with smolagents.
model = LiteLLMModel(
model_id="gemini/gemini-1.5-flash", # Using the LiteLLM identifier for the Gemini model
max_tokens=2096,
temperature=0.5,
)
# Load prompt templates from the YAML file
with open("prompts.yaml", 'r') as stream:
prompt_templates = yaml.safe_load(stream)
# Initialize the CodeAgent with the Gemini model and the defined tools
agent = CodeAgent(
model=model,
tools=[
final_answer,
web_search_tool,
get_current_time_in_timezone,
image_generation_tool
],
max_steps=6,
verbosity_level=1,
prompt_templates=prompt_templates
)
# Launch the Gradio user interface
GradioUI(agent).launch() |