Spaces:
Sleeping
Sleeping
Update app.py
Browse files
app.py
CHANGED
@@ -1,69 +1,80 @@
|
|
1 |
-
from smolagents import CodeAgent,
|
2 |
-
import datetime
|
3 |
-
import requests
|
4 |
-
import pytz
|
5 |
import yaml
|
6 |
-
|
7 |
|
|
|
8 |
from Gradio_UI import GradioUI
|
9 |
|
10 |
-
#
|
11 |
@tool
|
12 |
-
def
|
13 |
-
|
14 |
-
"""A tool that does nothing yet
|
15 |
Args:
|
16 |
-
|
17 |
-
|
18 |
"""
|
19 |
-
|
|
|
20 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
21 |
@tool
|
22 |
-
def
|
23 |
-
"""
|
24 |
Args:
|
25 |
-
|
26 |
"""
|
27 |
-
|
28 |
-
|
29 |
-
|
30 |
-
|
31 |
-
|
32 |
-
|
33 |
-
|
34 |
-
return f"Error fetching time for timezone '{timezone}': {str(e)}"
|
35 |
|
|
|
|
|
|
|
36 |
|
37 |
-
|
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'
|
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
|
59 |
max_steps=6,
|
60 |
verbosity_level=1,
|
61 |
grammar=None,
|
62 |
planning_interval=None,
|
63 |
-
name=
|
64 |
-
description=
|
65 |
prompt_templates=prompt_templates
|
66 |
)
|
67 |
|
68 |
-
|
69 |
GradioUI(agent).launch()
|
|
|
1 |
+
from smolagents import CodeAgent, HfApiModel, load_tool, tool
|
|
|
|
|
|
|
2 |
import yaml
|
3 |
+
import datetime
|
4 |
|
5 |
+
from tools.final_answer import FinalAnswerTool
|
6 |
from Gradio_UI import GradioUI
|
7 |
|
8 |
+
# Tool to calculate BMI and provide health feedback
|
9 |
@tool
|
10 |
+
def calculate_bmi(weight: float, height: float) -> str:
|
11 |
+
"""Calculates BMI and provides a health status.
|
|
|
12 |
Args:
|
13 |
+
weight: Weight in kilograms.
|
14 |
+
height: Height in meters.
|
15 |
"""
|
16 |
+
if height <= 0 or weight <= 0:
|
17 |
+
return "Invalid input. Please enter positive values for weight and height."
|
18 |
|
19 |
+
bmi = weight / (height ** 2)
|
20 |
+
status = ""
|
21 |
+
|
22 |
+
if bmi < 18.5:
|
23 |
+
status = "underweight"
|
24 |
+
elif 18.5 <= bmi < 24.9:
|
25 |
+
status = "normal weight"
|
26 |
+
elif 25 <= bmi < 29.9:
|
27 |
+
status = "overweight"
|
28 |
+
else:
|
29 |
+
status = "obese"
|
30 |
+
|
31 |
+
return f"Your BMI is {bmi:.2f}, which is considered {status}."
|
32 |
+
|
33 |
+
# Tool to analyze symptoms and suggest possible diseases
|
34 |
@tool
|
35 |
+
def analyze_symptoms(symptoms: str) -> str:
|
36 |
+
"""Analyzes symptoms and suggests possible diseases.
|
37 |
Args:
|
38 |
+
symptoms: A comma-separated list of symptoms.
|
39 |
"""
|
40 |
+
symptom_disease_mapping = {
|
41 |
+
"fever, cough": "Possible Flu or COVID-19",
|
42 |
+
"headache, nausea": "Possible Migraine or Food Poisoning",
|
43 |
+
"chest pain, shortness of breath": "Possible Heart Disease - Seek immediate medical help!",
|
44 |
+
"fatigue, weight loss": "Possible Thyroid Issues or Diabetes",
|
45 |
+
"stomach pain, diarrhea": "Possible Food Poisoning or Gastroenteritis"
|
46 |
+
}
|
|
|
47 |
|
48 |
+
for key, disease in symptom_disease_mapping.items():
|
49 |
+
if all(symptom in symptoms.lower() for symptom in key.split(", ")):
|
50 |
+
return f"Based on your symptoms ({symptoms}), you may have: {disease}. Consult a doctor for a proper diagnosis."
|
51 |
|
52 |
+
return "I'm not sure. Please consult a healthcare professional."
|
|
|
|
|
|
|
53 |
|
54 |
+
# Load model
|
55 |
+
final_answer = FinalAnswerTool()
|
56 |
model = HfApiModel(
|
57 |
+
max_tokens=2096,
|
58 |
+
temperature=0.5,
|
59 |
+
model_id='Qwen/Qwen2.5-Coder-32B-Instruct'
|
|
|
60 |
)
|
61 |
|
62 |
+
# Load prompt templates
|
|
|
|
|
|
|
63 |
with open("prompts.yaml", 'r') as stream:
|
64 |
prompt_templates = yaml.safe_load(stream)
|
65 |
+
|
66 |
+
# Define Agent
|
67 |
agent = CodeAgent(
|
68 |
model=model,
|
69 |
+
tools=[final_answer, calculate_bmi, analyze_symptoms], # Added tools here
|
70 |
max_steps=6,
|
71 |
verbosity_level=1,
|
72 |
grammar=None,
|
73 |
planning_interval=None,
|
74 |
+
name="HealthcareBot",
|
75 |
+
description="A healthcare assistant that calculates BMI and suggests potential diseases based on symptoms.",
|
76 |
prompt_templates=prompt_templates
|
77 |
)
|
78 |
|
79 |
+
# Launch Gradio UI
|
80 |
GradioUI(agent).launch()
|