Spaces:
Sleeping
Sleeping
| import gradio as gr | |
| import joblib | |
| import numpy as np | |
| # Load the trained model | |
| model = joblib.load("decision_tree_regressor_model.pkl") | |
| # Define the prediction function | |
| def predict_rpm( | |
| TM, U_percent, Thin, Thick, Neps, IPI, HI, ARKM, RKM_CV, MRKM, Elongation, Elon_CV | |
| ): | |
| features = np.array([ | |
| TM, U_percent, Thin, Thick, Neps, IPI, HI, ARKM, RKM_CV, MRKM, Elongation, Elon_CV | |
| ]).reshape(1, -1) | |
| prediction = model.predict(features) | |
| return round(prediction[0], 2) | |
| # Define sliders for each feature | |
| sliders = [ | |
| gr.Slider(minimum=3.8, maximum=4.2, step=0.1, label="TM"), | |
| gr.Slider(minimum=9.42, maximum=10.16, step=0.01, label="U_percent"), | |
| gr.Slider(minimum=0.0, maximum=4, step=1, label="Thin"), | |
| gr.Slider(minimum=18.0, maximum=40, step=1, label="Thick"), | |
| gr.Slider(minimum=56, maximum=101.0, step=1, label="Neps"), | |
| gr.Slider(minimum=89, maximum=122.0, step=1, label="IPI"), | |
| gr.Slider(minimum=3.51, maximum=4.45, step=0.1, label="HI"), | |
| gr.Slider(minimum=18.7, maximum=20.24, step=0.1, label="ARKM"), | |
| gr.Slider(minimum=6.89, maximum=8.6, step=0.1, label="RKM_CV"), | |
| gr.Slider(minimum=13.55, maximum=15.95, step=0.1, label="MRKM"), | |
| gr.Slider(minimum=3.75, maximum=5.52, step=0.1, label="Elongation"), | |
| gr.Slider(minimum=8.04, maximum=10.54, step=0.1, label="Elon_CV"), | |
| ] | |
| with gr.Blocks() as demo: | |
| gr.Markdown("## Loom RPM Prediction App") | |
| gr.Markdown("Adjust sliders for 12 features to predict Loom RPM using a Decision Tree Regressor.") | |
| with gr.Row(): | |
| sliders_row1 = sliders[0:4] | |
| for slider in sliders_row1: | |
| slider.render() | |
| with gr.Row(): | |
| sliders_row2 = sliders[4:8] | |
| for slider in sliders_row2: | |
| slider.render() | |
| with gr.Row(): | |
| sliders_row3 = sliders[8:12] | |
| for slider in sliders_row3: | |
| slider.render() | |
| output = gr.Number(label="Predicted RPM") | |
| predict_btn = gr.Button("Predict RPM") | |
| predict_btn.click( | |
| fn=predict_rpm, | |
| inputs=sliders, | |
| outputs=output | |
| ) | |
| # Create the interface | |
| # demo = gr.Interface( | |
| # fn=predict_rpm, | |
| # inputs=sliders, | |
| # outputs=gr.Number(label="Predicted RPM"), | |
| # title="RPM Prediction App", | |
| # description="Adjust the sliders for each of the 12 features to predict the RPM." | |
| # ) | |
| if __name__ == "__main__": | |
| demo.launch() | |