NavinduTharupathi commited on
Commit
23c5abc
·
verified ·
1 Parent(s): ae7a494

Update app.py

Browse files

Updated code with image generation, web search and time zone checking tools

Files changed (1) hide show
  1. app.py +30 -25
app.py CHANGED
@@ -1,23 +1,12 @@
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.
@@ -33,29 +22,45 @@ def get_current_time_in_timezone(timezone: str) -> str:
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,
@@ -65,5 +70,5 @@ agent = CodeAgent(
65
  prompt_templates=prompt_templates
66
  )
67
 
68
-
69
  GradioUI(agent).launch()
 
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
  from Gradio_UI import GradioUI
8
 
9
+ # Custom tool: Get current time in a specified timezone
 
 
 
 
 
 
 
 
 
 
10
  @tool
11
  def get_current_time_in_timezone(timezone: str) -> str:
12
  """A tool that fetches the current local time in a specified timezone.
 
22
  except Exception as e:
23
  return f"Error fetching time for timezone '{timezone}': {str(e)}"
24
 
25
+ # Custom tool: Generate an image using a text-to-image model
26
+ @tool
27
+ def generate_image(prompt: str) -> str:
28
+ """A tool that generates an image based on a text prompt.
29
+ Args:
30
+ prompt: A text description of the image to generate.
31
+ """
32
+ try:
33
+ # Use the image generation tool loaded from the Hub
34
+ image_url = image_generation_tool(prompt)
35
+ return f"Image generated successfully! Download it here: {image_url}"
36
+ except Exception as e:
37
+ return f"Error generating image: {str(e)}"
38
 
39
+ # Load the FinalAnswerTool
40
  final_answer = FinalAnswerTool()
41
 
42
+ # Initialize the model
 
 
43
  model = HfApiModel(
44
+ max_tokens=2096,
45
+ temperature=0.5,
46
+ model_id='Qwen/Qwen2.5-Coder-32B-Instruct', # Replace with another model if overloaded
47
+ custom_role_conversions=None,
48
  )
49
 
50
+ # Load the image generation tool from the Hub
 
51
  image_generation_tool = load_tool("agents-course/text-to-image", trust_remote_code=True)
52
 
53
+ # Load the DuckDuckGo search tool
54
+ web_search_tool = DuckDuckGoSearchTool()
55
+
56
+ # Load prompt templates from YAML file
57
  with open("prompts.yaml", 'r') as stream:
58
  prompt_templates = yaml.safe_load(stream)
59
+
60
+ # Initialize the agent with all tools
61
  agent = CodeAgent(
62
  model=model,
63
+ tools=[final_answer, web_search_tool, get_current_time_in_timezone, generate_image], # Add all tools here
64
  max_steps=6,
65
  verbosity_level=1,
66
  grammar=None,
 
70
  prompt_templates=prompt_templates
71
  )
72
 
73
+ # Launch the Gradio UI
74
  GradioUI(agent).launch()