MuhammadQASIM111 commited on
Commit
35229a1
·
verified ·
1 Parent(s): 1e989e3

Update app.py

Browse files
Files changed (1) hide show
  1. app.py +70 -20
app.py CHANGED
@@ -1,16 +1,16 @@
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
@@ -25,37 +25,88 @@ 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,5 +116,4 @@ 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
+ import pandas as pd
7
+ import fitz # PyMuPDF for PDF parsing
8
+ from io import StringIO, BytesIO
9
  from tools.final_answer import FinalAnswerTool
 
10
  from Gradio_UI import GradioUI
11
 
 
12
  @tool
13
+ def my_custom_tool(arg1: str, arg2: int) -> str:
 
14
  """A tool that does nothing yet
15
  Args:
16
  arg1: the first argument
 
25
  timezone: A string representing a valid timezone (e.g., 'America/New_York').
26
  """
27
  try:
 
28
  tz = pytz.timezone(timezone)
 
29
  local_time = datetime.datetime.now(tz).strftime("%Y-%m-%d %H:%M:%S")
30
  return f"The current local time in {timezone} is: {local_time}"
31
  except Exception as e:
32
  return f"Error fetching time for timezone '{timezone}': {str(e)}"
33
 
34
+ @tool
35
+ def cash_flow_forecast(doc_bytes: bytes, file_type: str) -> str:
36
+ """Forecasts monthly cash flow from a financial document.
37
+ Args:
38
+ doc_bytes: File bytes (PDF, CSV, or Excel).
39
+ file_type: One of 'pdf', 'csv', 'xlsx'.
40
+ """
41
+ try:
42
+ if file_type == 'pdf':
43
+ doc = fitz.open(stream=doc_bytes, filetype='pdf')
44
+ text = " ".join([page.get_text() for page in doc])
45
+ return f"PDF processed. Extracted text: {text[:300]}..."
46
+ elif file_type == 'csv':
47
+ df = pd.read_csv(BytesIO(doc_bytes))
48
+ elif file_type in ['xls', 'xlsx']:
49
+ df = pd.read_excel(BytesIO(doc_bytes))
50
+ else:
51
+ return "Unsupported file format."
52
+ df.columns = df.columns.str.lower()
53
+ if 'amount' not in df.columns:
54
+ df['amount'] = df.iloc[:, -1] # Assume last column is amount if not named
55
+ if 'date' not in df.columns:
56
+ df['date'] = pd.date_range(start='2023-01-01', periods=len(df))
57
+ df['date'] = pd.to_datetime(df['date'], errors='coerce')
58
+ monthly = df.resample('M', on='date').sum(numeric_only=True)
59
+ trend = monthly['amount'].rolling(window=3).mean().iloc[-1]
60
+ return f"Predicted average cash flow for next month: ${trend:.2f}"
61
+ except Exception as e:
62
+ return f"Error analyzing file: {str(e)}"
63
 
64
+ @tool
65
+ def report_generator(doc_bytes: bytes, file_type: str) -> str:
66
+ """Creates a business report from financial data.
67
+ Args:
68
+ doc_bytes: File bytes (PDF, CSV, or Excel).
69
+ file_type: File format type.
70
+ """
71
+ try:
72
+ if file_type == 'pdf':
73
+ doc = fitz.open(stream=doc_bytes, filetype='pdf')
74
+ return "\n".join([page.get_text() for page in doc][:2])
75
+ elif file_type == 'csv':
76
+ df = pd.read_csv(BytesIO(doc_bytes))
77
+ elif file_type in ['xls', 'xlsx']:
78
+ df = pd.read_excel(BytesIO(doc_bytes))
79
+ else:
80
+ return "Unsupported file format."
81
+ summary = df.describe(include='all').to_string()
82
+ return f"Business Report:\n{summary}"
83
+ except Exception as e:
84
+ return f"Failed to generate report: {str(e)}"
85
 
86
+ final_answer = FinalAnswerTool()
 
87
 
88
  model = HfApiModel(
89
+ max_tokens=2096,
90
+ temperature=0.5,
91
+ model_id='Qwen/Qwen2.5-Coder-32B-Instruct',
92
+ custom_role_conversions=None,
93
  )
94
 
 
 
95
  image_generation_tool = load_tool("agents-course/text-to-image", trust_remote_code=True)
96
 
97
  with open("prompts.yaml", 'r') as stream:
98
  prompt_templates = yaml.safe_load(stream)
99
+
100
  agent = CodeAgent(
101
  model=model,
102
+ tools=[
103
+ final_answer,
104
+ get_current_time_in_timezone,
105
+ my_custom_tool,
106
+ cash_flow_forecast,
107
+ report_generator,
108
+ image_generation_tool
109
+ ],
110
  max_steps=6,
111
  verbosity_level=1,
112
  grammar=None,
 
116
  prompt_templates=prompt_templates
117
  )
118
 
119
+ GradioUI(agent).launch()