A1843 commited on
Commit
97a2945
·
verified ·
1 Parent(s): b24bb96

Update app.py

Browse files
Files changed (1) hide show
  1. app.py +25 -40
app.py CHANGED
@@ -4,62 +4,46 @@ import requests
4
  import pytz
5
  import yaml
6
  from tools.final_answer import FinalAnswerTool
7
- from typing import List
8
 
9
- class WebSearchTool:
10
- """Outil qui permet de faire une recherche sur un site web donné en utilisant DuckDuckGo."""
11
-
12
- def __init__(self):
13
- self.duckduckgo_search_tool = load_tool("smolagents:DuckDuckGoSearchTool", trust_remote_code=True)
14
-
15
- def search(self, query: str, max_results: int = 5) -> List[str]:
16
- """Effectue une recherche sur DuckDuckGo et retourne les résultats limités à `max_results`.
17
-
18
- Args:
19
- query (str): La requête de recherche.
20
- max_results (int, optional): Le nombre maximum de résultats à retourner. Par défaut est 5.
21
 
22
- Returns:
23
- List[str]: Une liste des snippets des résultats de recherche.
24
- """
25
-
26
- # Utiliser l'outil DuckDuckGoSearchTool pour effectuer la recherche
27
- results = self.duckduckgo_search_tool(query, max_results=max_results)
28
-
29
- return [result['snippet'] for result in results]
 
 
30
 
31
- # Maintenons une docstring détaillée pour `get_current_time_in_timezone`
32
  @tool
33
  def get_current_time_in_timezone(timezone: str) -> str:
34
- """Récupère le temps local actuel dans un fuseau horaire spécifié.
35
-
36
  Args:
37
- timezone (str): Le fuseau horaire pour lequel récupérer le temps. Par exemple, 'UTC', 'Europe/Paris', etc.
38
-
39
- Returns:
40
- str: La chaîne représentant l'heure locale au format "AAAA-MM-JJ HH:MM:SS".
41
-
42
- Raises:
43
- Exception: Si le fuseau horaire spécifié est incorrect.
44
  """
45
-
46
  try:
 
47
  tz = pytz.timezone(timezone)
 
48
  local_time = datetime.datetime.now(tz).strftime("%Y-%m-%d %H:%M:%S")
49
  return f"The current local time in {timezone} is: {local_time}"
50
  except Exception as e:
51
  return f"Error fetching time for timezone '{timezone}': {str(e)}"
52
 
53
- final_answer = FinalAnswerTool()
54
 
 
55
  model = HfApiModel(
56
- max_tokens=2096,
57
- temperature=0.5,
58
- model_id='Qwen/Qwen2.5-Coder-32B-Instruct',
59
- custom_role_conversions=None,
60
  )
61
 
62
- # Importer l'outil d'image avec confiance
 
63
  image_generation_tool = load_tool("agents-course/text-to-image", trust_remote_code=True)
64
 
65
  with open("prompts.yaml", 'r') as stream:
@@ -67,7 +51,7 @@ with open("prompts.yaml", 'r') as stream:
67
 
68
  agent = CodeAgent(
69
  model=model,
70
- tools=[final_answer, WebSearchTool()], # Ajoutons notre nouveau tool
71
  max_steps=6,
72
  verbosity_level=1,
73
  grammar=None,
@@ -77,4 +61,5 @@ agent = CodeAgent(
77
  prompt_templates=prompt_templates
78
  )
79
 
80
- GradioUI(agent).launch()
 
 
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 important to specify the return type
13
+ # Keep this format for the tool description / 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
  model = HfApiModel(
39
+ max_tokens=2096,
40
+ temperature=0.5,
41
+ model_id='Qwen/Qwen2.5-Coder-32B-Instruct',
42
+ custom_role_conversions=None,
43
  )
44
 
45
+
46
+ # Import tool from Hub
47
  image_generation_tool = load_tool("agents-course/text-to-image", trust_remote_code=True)
48
 
49
  with open("prompts.yaml", 'r') as stream:
 
51
 
52
  agent = CodeAgent(
53
  model=model,
54
+ tools=[final_answer], # add your tools here (don't remove final_answer)
55
  max_steps=6,
56
  verbosity_level=1,
57
  grammar=None,
 
61
  prompt_templates=prompt_templates
62
  )
63
 
64
+
65
+ GradioUI(agent).launch()