WingNeville commited on
Commit
e5dfcee
·
verified ·
1 Parent(s): a8168d6

Upload agent

Browse files
Files changed (4) hide show
  1. agent.json +3 -0
  2. app.py +4 -1
  3. requirements.txt +1 -0
  4. tools/web_search.py +27 -0
agent.json CHANGED
@@ -1,11 +1,13 @@
1
  {
2
  "class": "CodeAgent",
3
  "tools": [
 
4
  "final_answer"
5
  ],
6
  "model": {
7
  "class": "InferenceClientModel",
8
  "data": {
 
9
  "model_id": "Qwen/Qwen2.5-Coder-32B-Instruct"
10
  }
11
  },
@@ -33,6 +35,7 @@
33
  "name": null,
34
  "description": null,
35
  "requirements": [
 
36
  "smolagents"
37
  ],
38
  "authorized_imports": [
 
1
  {
2
  "class": "CodeAgent",
3
  "tools": [
4
+ "web_search",
5
  "final_answer"
6
  ],
7
  "model": {
8
  "class": "InferenceClientModel",
9
  "data": {
10
+ "model": "Qwen/Qwen2.5-Coder-32B-Instruct",
11
  "model_id": "Qwen/Qwen2.5-Coder-32B-Instruct"
12
  }
13
  },
 
35
  "name": null,
36
  "description": null,
37
  "requirements": [
38
+ "duckduckgo_search",
39
  "smolagents"
40
  ],
41
  "authorized_imports": [
app.py CHANGED
@@ -5,14 +5,17 @@ from smolagents import GradioUI, CodeAgent, InferenceClientModel
5
  # Get current directory path
6
  CURRENT_DIR = os.path.dirname(os.path.abspath(__file__))
7
 
 
8
  from tools.final_answer import FinalAnswerTool as FinalAnswer
9
 
10
 
11
 
12
  model = InferenceClientModel(
 
13
  model_id='Qwen/Qwen2.5-Coder-32B-Instruct',
14
  )
15
 
 
16
  final_answer = FinalAnswer()
17
 
18
 
@@ -21,7 +24,7 @@ with open(os.path.join(CURRENT_DIR, "prompts.yaml"), 'r') as stream:
21
 
22
  agent = CodeAgent(
23
  model=model,
24
- tools=[],
25
  managed_agents=[],
26
  class='CodeAgent',
27
  max_steps=20,
 
5
  # Get current directory path
6
  CURRENT_DIR = os.path.dirname(os.path.abspath(__file__))
7
 
8
+ from tools.web_search import DuckDuckGoSearchTool as WebSearch
9
  from tools.final_answer import FinalAnswerTool as FinalAnswer
10
 
11
 
12
 
13
  model = InferenceClientModel(
14
+ model='Qwen/Qwen2.5-Coder-32B-Instruct',
15
  model_id='Qwen/Qwen2.5-Coder-32B-Instruct',
16
  )
17
 
18
+ web_search = WebSearch()
19
  final_answer = FinalAnswer()
20
 
21
 
 
24
 
25
  agent = CodeAgent(
26
  model=model,
27
+ tools=[web_search],
28
  managed_agents=[],
29
  class='CodeAgent',
30
  max_steps=20,
requirements.txt CHANGED
@@ -1 +1,2 @@
 
1
  smolagents
 
1
+ duckduckgo_search
2
  smolagents
tools/web_search.py ADDED
@@ -0,0 +1,27 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ from typing import Any, Optional
2
+ from smolagents.tools import Tool
3
+ import duckduckgo_search
4
+
5
+ class DuckDuckGoSearchTool(Tool):
6
+ name = "web_search"
7
+ description = "Performs a duckduckgo web search based on your query (think a Google search) then returns the top search results."
8
+ inputs = {'query': {'type': 'string', 'description': 'The search query to perform.'}}
9
+ output_type = "string"
10
+
11
+ def __init__(self, max_results=10, **kwargs):
12
+ super().__init__()
13
+ self.max_results = max_results
14
+ try:
15
+ from duckduckgo_search import DDGS
16
+ except ImportError as e:
17
+ raise ImportError(
18
+ "You must install package `duckduckgo_search` to run this tool: for instance run `pip install duckduckgo-search`."
19
+ ) from e
20
+ self.ddgs = DDGS(**kwargs)
21
+
22
+ def forward(self, query: str) -> str:
23
+ results = self.ddgs.text(query, max_results=self.max_results)
24
+ if len(results) == 0:
25
+ raise Exception("No results found! Try a less restrictive/shorter query.")
26
+ postprocessed_results = [f"[{result['title']}]({result['href']})\n{result['body']}" for result in results]
27
+ return "## Search Results\n\n" + "\n\n".join(postprocessed_results)