GhozlaneHadri commited on
Commit
c66d381
·
verified ·
1 Parent(s): c4446c7

Update app.py

Browse files
Files changed (1) hide show
  1. app.py +18 -21
app.py CHANGED
@@ -1,4 +1,4 @@
1
- from smolagents import CodeAgent,DuckDuckGoSearchTool, HfApiModel,load_tool,tool
2
  import datetime
3
  import requests
4
  import pytz
@@ -7,10 +7,8 @@ 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
@@ -25,37 +23,35 @@ def get_current_time_in_timezone(timezone: str) -> str:
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,
@@ -65,8 +61,9 @@ agent = CodeAgent(
65
  prompt_templates=prompt_templates
66
  )
67
 
68
- # Optional: You can run a test outside Gradio
69
- image = image_generator(prompt="A high-quality, photorealistic image of a cat sleeping on a windowsill.")
70
- final_answer(image)
71
 
 
72
  GradioUI(agent).launch()
 
1
+ from smolagents import CodeAgent, DuckDuckGoSearchTool, HfApiModel, load_tool, tool
2
  import datetime
3
  import requests
4
  import pytz
 
7
 
8
  from Gradio_UI import GradioUI
9
 
 
10
  @tool
11
+ def my_custom_tool(arg1: str, arg2: int) -> str:
 
12
  """A tool that does nothing yet
13
  Args:
14
  arg1: the first argument
 
23
  timezone: A string representing a valid timezone (e.g., 'America/New_York').
24
  """
25
  try:
 
26
  tz = pytz.timezone(timezone)
 
27
  local_time = datetime.datetime.now(tz).strftime("%Y-%m-%d %H:%M:%S")
28
  return f"The current local time in {timezone} is: {local_time}"
29
  except Exception as e:
30
  return f"Error fetching time for timezone '{timezone}': {str(e)}"
31
 
 
32
  final_answer = FinalAnswerTool()
33
 
 
 
 
34
  model = HfApiModel(
35
+ max_tokens=2096,
36
+ temperature=0.5,
37
+ model_id='Qwen/Qwen2.5-Coder-32B-Instruct',
38
+ custom_role_conversions=None,
39
  )
40
 
41
+ # Load image generation tool correctly
 
42
  image_generation_tool = load_tool("agents-course/text-to-image", trust_remote_code=True)
43
 
44
  with open("prompts.yaml", 'r') as stream:
45
  prompt_templates = yaml.safe_load(stream)
46
+
47
  agent = CodeAgent(
48
  model=model,
49
+ tools=[
50
+ final_answer,
51
+ image_generation_tool,
52
+ get_current_time_in_timezone,
53
+ my_custom_tool
54
+ ],
55
  max_steps=6,
56
  verbosity_level=1,
57
  grammar=None,
 
61
  prompt_templates=prompt_templates
62
  )
63
 
64
+ # 🚫 REMOVE THIS, agent should run everything via .run() inside Gradio
65
+ # image = image_generator(prompt="A high-quality, photorealistic image of a cat sleeping on a windowsill.")
66
+ # final_answer(image)
67
 
68
+ # ✅ Launch Gradio agent
69
  GradioUI(agent).launch()