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 from functions import decode_features, get_model def fancy_header(text, font_size=24): res = f'{text}' st.markdown(res, unsafe_allow_html=True ) st.title('⛅️Air Quality Prediction Project🌩') progress_bar = st.sidebar.header('⚙️ Working Progress') progress_bar = st.sidebar.progress(0) st.write(36 * "-") fancy_header('\n📡 Connecting to Hopsworks Feature Store...') project = hopsworks.login() fs = project.get_feature_store() feature_view = fs.get_feature_view( name = 'oslo_air_quality_fv', version = 1 ) st.write("Successfully connected!✔️") progress_bar.progress(20) st.write(36 * "-") fancy_header('\n☁️ Getting batch data from Feature Store...') start_date = datetime.now() - timedelta(days=1) start_time = int(start_date.timestamp()) * 1000 # X = feature_view.get_batch_data(start_time=start_time) X = feature_view.get_batch_data(start_time=1673625600000) progress_bar.progress(50) print(X.date.values) latest_date_unix = str(X.date.values[0])[:10] latest_date = time.ctime(int(latest_date_unix)) st.write(f"⏱ Data for {latest_date}") X = X.drop(columns=["date"]).fillna(0) print("X is \n %s" % X) data_to_display = decode_features(X, feature_view=feature_view) data_to_display["city"] = "Oslo" # print(data_to_display) progress_bar.progress(60) st.write(36 * "-") fancy_header(f"🗺 Processing the map...") fig = Figure(width=550,height=350) my_map = folium.Map(location=[58, 20], zoom_start=3.71) fig.add_child(my_map) folium.TileLayer('Stamen Terrain').add_to(my_map) folium.TileLayer('Stamen Toner').add_to(my_map) folium.TileLayer('Stamen Water Color').add_to(my_map) folium.TileLayer('cartodbpositron').add_to(my_map) folium.TileLayer('cartodbdark_matter').add_to(my_map) folium.LayerControl().add_to(my_map) data_to_display = data_to_display[["city", "temp", "humidity", "conditions", "aqi"]] cities_coords = {("Oslo", "Norway"): [59.9139, 10.7522]} data_to_display = data_to_display.set_index("city") cols_names_dict = {"temp": "Temperature", "humidity": "Humidity", "conditions": "Conditions", "aqi": "AQI"} data_to_display = data_to_display.rename(columns=cols_names_dict) cols_ = ["Temperature", "Humidity", "AQI"] data_to_display[cols_] = data_to_display[cols_].apply(lambda x: round(x, 1)) for city, country in cities_coords: text = f"""
Country: | {country} |
---|---|
{column}: | {data_to_display.loc[city][column]} |