File size: 1,478 Bytes
d1719f7
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
import gradio as gr
import pandas as pd
import joblib

# Load the trained XGBoost model
best_model = joblib.load("xgb_model.pkl")

# Define the prediction function
def predict_fuel_rate(loaded_drv, empty_drv, eng_speed, empty_stop, loading_stop, loaded_stop):
    input_data = {
        'loaded_drv_time_percycle': loaded_drv,
        'empty_drv_time_percycle': empty_drv,
        'Eng_Speed_Ave': eng_speed,
        'empty_stop_time_percycle': empty_stop,
        'loadingstoptime_percycle': loading_stop,
        'loaded_stop_time_percycle': loaded_stop
    }
    input_df = pd.DataFrame([input_data])
    prediction = best_model.predict(input_df)[0]
    return round(prediction, 2)

# Gradio Interface
interface = gr.Interface(
    fn=predict_fuel_rate,
    inputs=[
        gr.Slider(3, 60, value=18, label="Loaded Drive Time per Cycle"),
        gr.Slider(2, 51, value=16, label="Empty Drive Time per Cycle"),
        gr.Slider(1051, 1596, value=1416, label="Engine Speed Average"),
        gr.Slider(0.2, 24.6, value=4.2, label="Empty Stop Time per Cycle"),
        gr.Slider(2, 18, value=2, label="Loading Stop Time per Cycle"),
        gr.Slider(0.4, 9, value=0.4, label="Loaded Stop Time per Cycle"),
    ],
    outputs=gr.Number(label="Predicted Fuel Rate per Cycle (L)"),
    title="🚛 Fuel Rate What-If Simulator",
    description="Adjust the sliders to simulate different operating conditions and estimate fuel consumption."
)

# Launch the app
interface.launch()