jkim03 commited on
Commit
d19283f
·
verified ·
1 Parent(s): 24a9bdf

Create app.py

Browse files
Files changed (1) hide show
  1. app.py +42 -0
app.py ADDED
@@ -0,0 +1,42 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ from fastapi import FastAPI
2
+ from pydantic import BaseModel
3
+ import joblib
4
+ import pandas as pd
5
+ import json
6
+
7
+ # Load models
8
+ scaler = joblib.load("scaler.joblib")
9
+ gmm = joblib.load("gmm_model.joblib")
10
+ with open("cluster_fatigue_map.json") as f:
11
+ cluster_fatigue_map = json.load(f)
12
+
13
+ feature_cols = [
14
+ "AVRR", "SDNN", "RMSSD", "PNN50", "Coefficient_of_Variation",
15
+ "Age", "Weight", "Height"
16
+ ]
17
+
18
+ # Define input schema
19
+ class FatigueInput(BaseModel):
20
+ AVRR: float
21
+ SDNN: float
22
+ RMSSD: float
23
+ PNN50: float
24
+ Coefficient_of_Variation: float
25
+ Age: int
26
+ Weight: float
27
+ Height: float
28
+
29
+ # Create FastAPI app
30
+ app = FastAPI()
31
+
32
+ @app.post("/predict")
33
+ def predict(input_data: FatigueInput):
34
+ try:
35
+ input_dict = input_data.dict()
36
+ input_df = pd.DataFrame([input_dict])[feature_cols]
37
+ scaled_input = scaler.transform(input_df)
38
+ cluster = gmm.predict(scaled_input)[0]
39
+ fatigue_level = cluster_fatigue_map[str(cluster)]
40
+ return {"cluster": int(cluster), "fatigue_level": fatigue_level}
41
+ except Exception as e:
42
+ return {"error": str(e)}