Spaces:
Running
Running
| import os | |
| from tools import ( | |
| get_area_lat_lon, | |
| get_wave_forecast, | |
| get_wind_forecast, | |
| ) | |
| from any_agent.logging import logger | |
| from any_agent.tools.web_browsing import search_tavily, search_web, visit_webpage | |
| MODEL_OPTIONS = [ | |
| "openai/gpt-4.1-nano", | |
| "openai/gpt-4.1-mini", | |
| "openai/gpt-4o", | |
| "gemini/gemini-2.0-flash-lite", | |
| "gemini/gemini-2.0-flash", | |
| ] | |
| DEFAULT_EVALUATION_MODEL = MODEL_OPTIONS[0] | |
| DEFAULT_EVALUATION_CRITERIA = [ | |
| { | |
| "criteria": "Check if the agent considered at least three surf spot options", | |
| }, | |
| { | |
| "criteria": "Check if the agent gathered wind forecasts for each surf spot being evaluated.", | |
| }, | |
| { | |
| "criteria": "Check if the agent gathered wave forecasts for each surf spot being evaluated.", | |
| }, | |
| { | |
| "criteria": "Check if the agent used any web search tools to explore which surf spots should be considered", | |
| }, | |
| { | |
| "criteria": "Check if the final answer contains any description about the weather (air temp, chance of rain, etc) at the chosen location", | |
| }, | |
| { | |
| "criteria": "Check if the final answer includes one of the surf spots evaluated by tools", | |
| }, | |
| { | |
| "criteria": "Check if the final answer includes information about some alternative surf spots if the user is not satisfied with the chosen one", | |
| }, | |
| ] | |
| DEFAULT_TOOLS = [ | |
| get_wind_forecast, | |
| get_wave_forecast, | |
| get_area_lat_lon, | |
| search_web, | |
| visit_webpage, | |
| ] | |
| if os.getenv("TAVILY_API_KEY"): | |
| DEFAULT_TOOLS.append(search_tavily) | |
| else: | |
| logger.warning("TAVILY_API_KEY not set, skipping Tavily search tool") | |