Ubik80 commited on
Commit
ad60877
·
verified ·
1 Parent(s): ae7a494

Update app.py

Browse files
Files changed (1) hide show
  1. app.py +58 -37
app.py CHANGED
@@ -1,61 +1,82 @@
1
- from smolagents import CodeAgent,DuckDuckGoSearchTool, HfApiModel,load_tool,tool
2
- import datetime
 
3
  import requests
4
- import pytz
5
  import yaml
6
  from tools.final_answer import FinalAnswerTool
7
 
8
  from Gradio_UI import GradioUI
9
 
10
- # Below is an example of a tool that does nothing. Amaze us with your creativity !
11
- @tool
12
- def my_custom_tool(arg1:str, arg2:int)-> str: #it's import to specify the return type
13
- #Keep this format for the description / args / args description but feel free to modify the tool
14
- """A tool that does nothing yet
15
- Args:
16
- arg1: the first argument
17
- arg2: the second argument
18
- """
19
- return "What magic will you build ?"
20
 
21
  @tool
22
- def get_current_time_in_timezone(timezone: str) -> str:
23
- """A tool that fetches the current local time in a specified timezone.
 
24
  Args:
25
- timezone: A string representing a valid timezone (e.g., 'America/New_York').
 
 
 
 
26
  """
27
- try:
28
- # Create timezone object
29
- tz = pytz.timezone(timezone)
30
- # Get current time in that timezone
31
- local_time = datetime.datetime.now(tz).strftime("%Y-%m-%d %H:%M:%S")
32
- return f"The current local time in {timezone} is: {local_time}"
33
- except Exception as e:
34
- return f"Error fetching time for timezone '{timezone}': {str(e)}"
35
 
 
36
 
37
- final_answer = FinalAnswerTool()
 
38
 
39
- # 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:
40
- # model_id='https://pflgm2locj2t89co.us-east-1.aws.endpoints.huggingface.cloud'
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
41
 
42
- model = HfApiModel(
43
- max_tokens=2096,
44
- temperature=0.5,
45
- model_id='Qwen/Qwen2.5-Coder-32B-Instruct',# it is possible that this model may be overloaded
46
- custom_role_conversions=None,
47
- )
48
 
 
 
 
 
 
 
 
49
 
50
  # Import tool from Hub
51
- image_generation_tool = load_tool("agents-course/text-to-image", trust_remote_code=True)
52
 
53
- with open("prompts.yaml", 'r') as stream:
54
- prompt_templates = yaml.safe_load(stream)
55
 
56
  agent = CodeAgent(
57
  model=model,
58
- tools=[final_answer], ## add your tools here (don't remove final answer)
59
  max_steps=6,
60
  verbosity_level=1,
61
  grammar=None,
 
1
+ import os
2
+ os.system("pip install 'smolagents[openai]'")
3
+ from smolagents import CodeAgent,DuckDuckGoSearchTool, HfApiModel,load_tool,tool, OpenAIServerModel
4
  import requests
 
5
  import yaml
6
  from tools.final_answer import FinalAnswerTool
7
 
8
  from Gradio_UI import GradioUI
9
 
10
+
11
+
 
 
 
 
 
 
 
 
12
 
13
  @tool
14
+ def search_duckduckgo(query: str, num_results: int = 3) -> str:
15
+ """Performs a web search using DuckDuckGo and returns multiple relevant results.
16
+
17
  Args:
18
+ query: The search term.
19
+ num_results: Number of search results to return (default: 3).
20
+
21
+ Returns:
22
+ A formatted list of search results including title, summary, and link.
23
  """
24
+ search_tool = DuckDuckGoSearchTool()
25
+ results = search_tool(query)
 
 
 
 
 
 
26
 
27
+ print("DEBUG - Raw results from DuckDuckGo:\n", results)
28
 
29
+ if not results or "## Search Results" not in results:
30
+ return f"No relevant results found for '{query}'."
31
 
32
+ result_lines = results.split("\n")
33
+ parsed_results = []
34
+
35
+ for i in range(len(result_lines)):
36
+ if result_lines[i].startswith("[") and len(parsed_results) < num_results:
37
+ try:
38
+ title_end = result_lines[i].index("]") # Find the end of the title
39
+ title = result_lines[i][1:title_end] # Extract title
40
+ link = result_lines[i][title_end+2:].strip() # Extract link
41
+
42
+
43
+ if link.endswith(")"):
44
+ link = link[:-1]
45
+
46
+ # Ensure the link is valid
47
+ if not link.startswith("http"):
48
+ continue # Skip invalid links
49
+
50
+ summary = result_lines[i+1].strip() if i+1 < len(result_lines) else "No summary available."
51
+
52
+ # Correct Markdown format
53
+ formatted_result = f"🔎 **[{title}]({link})**\n📌 {summary}"
54
+ parsed_results.append(formatted_result)
55
+
56
+ except Exception as e:
57
+ print(f"Error parsing result: {e}")
58
+ continue # Skip problematic entries
59
 
60
+ if not parsed_results:
61
+ return f"No valid results found for '{query}'."
62
+
63
+ return "\n\n".join(parsed_results) # Return formatted results
 
 
64
 
65
+ model = OpenAIServerModel(
66
+ max_tokens=2096,
67
+ temperature=0.5,
68
+ model_id="gpt-4",
69
+ api_key=os.getenv("OPENAI_API_KEY"),
70
+ custom_role_conversions=None,
71
+ )
72
 
73
  # Import tool from Hub
74
+ HF_API_KEY = os.getenv("HF_TOKEN")
75
 
 
 
76
 
77
  agent = CodeAgent(
78
  model=model,
79
+ tools=[final_answer, search_duckduckgo], ## add your tools here (don't remove final answer)
80
  max_steps=6,
81
  verbosity_level=1,
82
  grammar=None,