|
import gradio as gr |
|
from PIL import Image |
|
import requests |
|
import hopsworks |
|
import joblib |
|
import pandas as pd |
|
|
|
|
|
|
|
|
|
model_wine_dir = "wine_models" |
|
model_red_wine_name = "wine_red_model" |
|
model_red_wine_version = 1 |
|
model_white_wine_name = "wine_white_model" |
|
model_white_wine_version = 1 |
|
|
|
def wine_quality(wine_type, fixed_acidity, volatile_acidity, citric_acid, residual_sugar, chlorides, |
|
free_sulfur_dioxide, total_sulfur_dioxide, density, ph, sulphates, alcohol): |
|
print("Calling wine_quality() function") |
|
df = pd.DataFrame([[fixed_acidity, volatile_acidity, citric_acid, residual_sugar, chlorides, |
|
free_sulfur_dioxide, total_sulfur_dioxide, density, ph, sulphates, alcohol]], |
|
columns=['fixed_acidity', 'volatile_acidity', 'citric_acid', 'residual_sugar', |
|
'chlorides', 'free_sulfur_dioxide', 'total_sulfur_dioxide', 'density', |
|
'ph', 'sulphates', 'alcohol']) |
|
print("Predicting...") |
|
print(df) |
|
|
|
if wine_type.lower() == 'red': |
|
quality = red_wine_local_model.predict(df) |
|
elif wine_type.lower() == 'white': |
|
quality = white_wine_local_model.predict(df) |
|
else: |
|
quality = "Unknown wine type. Only 'red' and 'white' are known." |
|
|
|
return quality |
|
|
|
|
|
print("Logging in to Hopsworks...") |
|
project = hopsworks.login() |
|
|
|
print("Getting feature store...") |
|
fs = project.get_feature_store() |
|
|
|
print("Getting model registry...") |
|
mr = project.get_model_registry() |
|
|
|
print("Getting model for red wine: ...") |
|
model_red_wine = mr.get_model(model_red_wine_name, version=model_red_wine_version) |
|
|
|
print("Downloading model for red wine...") |
|
model_red_dir = model_red_wine.download() |
|
|
|
print("Initializing model red wine locally...") |
|
red_wine_local_model = joblib.load(model_red_dir + f"/{model_red_wine_name}.pkl") |
|
|
|
print("Getting model for white wine: ...") |
|
model_white_wine = mr.get_model(model_white_wine_name, version=model_white_wine_version) |
|
|
|
print("Downloading model for white wine...") |
|
model_white_dir = model_white_wine.download() |
|
|
|
print("Initializing model white wine locally...") |
|
white_wine_local_model = joblib.load(model_white_dir + f"/{model_white_wine_name}.pkl") |
|
|
|
|
|
|
|
iface = gr.Interface(fn=wine_quality, |
|
inputs=["text", "number", "number", "number", "number", "number", |
|
"number", "number", "number", "number", "number", "number"], |
|
outputs="text", |
|
examples=[['red', 7.4, 0.70, 0.00, 1.9, 0.076, 11.0, 34.0, 0.9978, 3.51, 0.56, 9.4], |
|
['white', 7.0, 0.27, 0.36, 20.7, 0.045, 45.0, 170.0, 1.0010, 3.00, 0.45, 8.8]]) |
|
|
|
iface.launch() |
|
|