RajendrakumarPachaiappan's picture
Upload folder using huggingface_hub
3192b37 verified
import streamlit as st
import joblib
import pandas as pd
import numpy as np
from huggingface_hub import hf_hub_download
REPO_ID_MODEL = "RajendrakumarPachaiappan/engine-predictive-model"
MODEL_FILENAME = "final_random_forest_model.joblib"
SCALER_FILENAME = "standard_scaler.joblib"
# Feature Column for Input
FEATURE_COLS = [
'Engine_RPM', 'Lub_Oil_Pressure', 'Fuel_Pressure',
'Coolant_Pressure', 'Lub_Oil_Temperature', 'Coolant_Temperature'
]
# Caching Function to Load Model and Scaler
@st.cache_resource
def load_artifacts():
try:
with st.spinner("Downloading and loading model artifacts..."):
# Download and load the model
model_path = hf_hub_download(repo_id=REPO_ID_MODEL, filename=MODEL_FILENAME, repo_type="model")
model = joblib.load(model_path)
# Download and load the scaler
scaler_path = hf_hub_download(repo_id=REPO_ID_MODEL, filename=SCALER_FILENAME, repo_type="model")
scaler = joblib.load(scaler_path)
return model, scaler
except Exception as e:
st.error(f"CRITICAL ERROR: Failed to load model or scaler. Check repository ID and filenames. Error: {e}")
return None, None
# Load the model and scaler
model, scaler = load_artifacts()
# Streamlit Setup
st.set_page_config(
page_title="Engine Predictive Maintenance",
layout="centered",
initial_sidebar_state="expanded"
)
st.title("Predict Engine Condition")
st.markdown(
"This model forecasts potential engine failures, classifying the status as **Normal (0)** or requiring **Immediate Maintenance (1)**."
)
st.markdown(
"**Note:** Adjust the sliders below with current sensor readings to check the engine condition."
)
if model is None or scaler is None:
st.stop()
st.header("Sensor Readings")
ranges = {
'Engine_RPM': (61.0, 2239.0, 791.0),
'Lub_Oil_Pressure': (0.0, 7.3, 3.3),
'Fuel_Pressure': (0.0, 21.1, 6.7),
'Coolant_Pressure': (0.0, 7.5, 2.3),
'Lub_Oil_Temperature': (71.3, 89.6, 77.6),
'Coolant_Temperature': (61.7, 195.5, 78.4),
}
input_values = {}
col1, col2 = st.columns(2)
columns = [col1, col2]
for i, col_name in enumerate(FEATURE_COLS):
current_col = columns[i % 2]
min_val, max_val, default_val = ranges[col_name]
label = col_name.replace('_', ' ')
unit = ""
if "RPM" in col_name:
unit = " (rev/min)"
elif "Pressure" in col_name:
unit = " (bar/kPa)"
elif "Temperature" in col_name:
unit = " (°C)"
with current_col:
input_values[col_name] = st.slider(
label=f"{label}{unit}",
min_value=min_val,
max_value=max_val,
value=default_val,
step=0.1,
help=f"Current reading for {label}. Full data range: [{min_val}, {max_val}]"
)
# Prediction Logic
if st.button("Predict Engine Condition", type="primary"):
input_df = pd.DataFrame([input_values], columns=FEATURE_COLS)
input_scaled = scaler.transform(input_df)
prediction = model.predict(input_scaled)[0]
st.subheader("Prediction Result")
if prediction == 1:
st.error(
"FAULTY (1): Immediate Maintenance Required! "
"High probability of engine failure detected. Check for high RPM, low pressures, or extreme temperatures."
)
else:
st.success(
"NORMAL (0): Operating within expected parameters. "
"Engine health is currently good."
)
st.caption(f"Raw Model Prediction (0=Normal, 1=Faulty): {prediction}")