Nihar14 commited on
Commit
6b7f14c
·
verified ·
1 Parent(s): 560bca3

Update app.py

Browse files
Files changed (1) hide show
  1. app.py +49 -27
app.py CHANGED
@@ -1,22 +1,32 @@
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:
@@ -25,43 +35,55 @@ 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,
62
  planning_interval=None,
63
  name=None,
64
  description=None,
65
- prompt_templates=prompt_templates
66
  )
 
67
  GradioUI(agent).launch()
 
1
+ from smolagents import CodeAgent, HfApiModel, load_tool, tool
2
  import datetime
3
  import requests
4
  import pytz
5
  import yaml
6
+ import os
7
  from tools.final_answer import FinalAnswerTool
 
8
  from Gradio_UI import GradioUI
9
 
10
+ # Ensure the latest smolagents version: `pip install --upgrade smolagents`
11
+ # Ensure prompts.yaml matches the provided structure with system_prompt, final_answer, planning, and managed_agent
12
+ # Set your Hugging Face API token as an environment variable if required
13
+ HF_TOKEN = os.environ.get("HF_TOKEN")
14
+
15
  @tool
16
+ def get_motivational_quote(category: str = "inspirational") -> str:
17
+ """A tool that fetches a random motivational quote from the Quotable API.
 
18
  Args:
19
+ category: A string representing the quote category (e.g., 'inspirational', 'life'). Defaults to 'inspirational'.
 
20
  """
21
+ try:
22
+ response = requests.get(f"https://api.quotable.io/random?tags={category}")
23
+ response.raise_for_status()
24
+ data = response.json()
25
+ quote = data['content']
26
+ author = data['author']
27
+ return f"\"{quote}\" - {author}"
28
+ except Exception as e:
29
+ return f"Error fetching quote: {str(e)}"
30
 
31
  @tool
32
  def get_current_time_in_timezone(timezone: str) -> str:
 
35
  timezone: A string representing a valid timezone (e.g., 'America/New_York').
36
  """
37
  try:
 
38
  tz = pytz.timezone(timezone)
 
39
  local_time = datetime.datetime.now(tz).strftime("%Y-%m-%d %H:%M:%S")
40
  return f"The current local time in {timezone} is: {local_time}"
41
  except Exception as e:
42
  return f"Error fetching time for timezone '{timezone}': {str(e)}"
43
 
 
44
  final_answer = FinalAnswerTool()
45
+ image_generation_tool = load_tool("agents-course/text-to-image", trust_remote_code=True)
46
 
47
+ with open("prompts.yaml", 'r') as stream:
48
+ prompt_templates = yaml.safe_load(stream)
49
+
50
+ # Restructure prompt_templates to match CodeAgent expectations
51
+ # Handle cases where planning and managed_agent are parsed incorrectly
52
+ restructured_templates = {
53
+ "system_prompt": prompt_templates.get("system_prompt", ""),
54
+ "final_answer": prompt_templates.get("final_answer", ""),
55
+ "planning": {
56
+ "initial_facts": prompt_templates.get("planning", {}).get("initial_facts", ""),
57
+ "initial_plan": prompt_templates.get("planning", {}).get("initial_plan", ""),
58
+ "update_facts_pre_messages": prompt_templates.get("planning", {}).get("update_facts_pre_messages", ""),
59
+ "update_facts_post_messages": prompt_templates.get("planning", {}).get("update_facts_post_messages", ""),
60
+ "update_plan_pre_messages": prompt_templates.get("planning", {}).get("update_plan_pre_messages", ""),
61
+ "update_plan_post_messages": prompt_templates.get("planning", {}).get("update_plan_post_messages", "")
62
+ },
63
+ "managed_agent": {
64
+ "task": prompt_templates.get("managed_agent", {}).get("task", ""),
65
+ "report": prompt_templates.get("managed_agent", {}).get("report", "")
66
+ }
67
+ }
68
 
69
  model = HfApiModel(
70
+ model_id="Qwen/Qwen2.5-Coder-32B-Instruct",
71
+ token=HF_TOKEN,
72
+ max_tokens=2096,
73
+ temperature=0.5,
74
+ custom_role_conversions=None
75
  )
76
 
 
 
 
 
 
 
 
77
  agent = CodeAgent(
78
  model=model,
79
+ tools=[get_motivational_quote, get_current_time_in_timezone, image_generation_tool, final_answer],
80
  max_steps=6,
81
  verbosity_level=1,
82
  grammar=None,
83
  planning_interval=None,
84
  name=None,
85
  description=None,
86
+ prompt_templates=restructured_templates
87
  )
88
+
89
  GradioUI(agent).launch()