import streamlit as st import hopsworks import joblib import pandas as pd import numpy as np import folium from streamlit_folium import st_folium, folium_static import json import time from datetime import timedelta, datetime from branca.element import Figure import gradio as gr from functions import decode_features, get_model, get_weather_df, get_weather_data project = hopsworks.login() fs = project.get_feature_store() feature_view = fs.get_feature_view( name = 'oslo_air_quality_fv', version = 1 ) # model = get_model(project=project, # model_name="air_quality_model", # evaluation_metric="f1_score", # sort_metrics_by="max") mr = project.get_model_registry() model = mr.get_model("air_quality_model",version = 3) model_dir = model.download() model = joblib.load(model_dir + "/model.pkl") def pred(name): str1 = " " for i in range(8): target_date = datetime.today() + timedelta(days=i) target_date = target_date.strftime('%Y-%m-%d') data_weather = [get_weather_data('oslo',target_date)] df_weather = get_weather_df(data_weather) df_weather['conditions'] = df_weather['conditions'].replace(['Rain','Clear','Snow','Partially cloudy','Overcast','Snow, Partially cloudy', 'Rain, Partially cloudy','Rain, Overcast','Snow, Overcast', 'Snow, Freezing Drizzle/Freezing Rain, Overcast','Snow, Rain', 'Snow, Rain, Freezing Drizzle/Freezing Rain, Ice, Overcast', 'Snow, Rain, Freezing Drizzle/Freezing Rain, Overcast','Snow, Rain, Ice, Overcast', 'Snow, Rain, Overcast','Snow, Rain, Partially cloudy'],[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15]) df_weather = df_weather.drop(columns=["date"]).fillna(0) df_weather.loc[0,"aqi"] = 0 print(df_weather) # print(feature_view.columns) preds = model.predict(df_weather) print(preds) if(i!=0): str1 += target_date + " predicted aqi:" + str(int(preds))+"\n" return str1 # next_day_date = datetime.today() + timedelta(days=i) # next_day = next_day_date.strftime ('%d/%m/%Y') demo = gr.Interface(fn=pred,title="Predict AQI of Oslo" ,inputs="text", outputs="text") if __name__ == "__main__": demo.launch()