File size: 2,574 Bytes
53267d3
6227435
baacba5
 
53267d3
bb607ff
53267d3
 
 
 
 
 
 
 
 
 
 
baacba5
 
53267d3
 
baacba5
6227435
baacba5
6227435
53267d3
 
 
6227435
baacba5
6227435
baacba5
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
6227435
 
 
baacba5
6227435
 
c9dc531
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
import gradio as gr
from risk_model import predict_risk, retrain_model, get_history_df
import pandas as pd
import matplotlib.pyplot as plt

with gr.Blocks() as demo:
    gr.Markdown("## 🔥 Heating Mantle Safety Risk Predictor")

    with gr.Row():
        temp = gr.Number(label="Max Temperature (°C)", value=100)
        duration = gr.Number(label="Duration (min)", value=30)

    with gr.Row():
        predict_btn = gr.Button("🔍 Predict")
        retrain_btn = gr.Button("🔁 Retrain Model")

    result = gr.Textbox(label="Risk Prediction")
    alert = gr.Textbox(label="🚨 Alert Message")
    ist_time = gr.Textbox(label="Timestamp (IST)")
    retrain_output = gr.Textbox(label="Retrain Status")

    summary = gr.Markdown()
    history_table = gr.Dataframe(headers=["Temperature", "Duration", "Risk", "Timestamp"], label="📈 Prediction History")

    plot = gr.Plot(label="📊 Risk Trend Chart")

    def classify(temp, duration):
        if temp <= 0 or duration <= 0:
            return "❌ Invalid", "Invalid", "Invalid", "", pd.DataFrame(), plt.figure()

        risk, timestamp = predict_risk(temp, duration)

        if risk == "Low":
            alert_msg = "✅ SAFE - No action needed"
        elif risk == "Moderate":
            alert_msg = "⚠️ SAFE - Monitor closely"
        else:
            alert_msg = "🔥 SHUTDOWN - Immediate attention needed"

        summary_md = f"""
### 🔎 Summary
- **Max Temp**: {temp} °C  
- **Duration**: {duration} min  
- **Risk**: {risk}  
- **Timestamp**: {timestamp}  
- **Alert**: {alert_msg}
"""

        df = get_history_df()

        # Convert Risk to numeric for plotting
        risk_map = {'Low': 1, 'Moderate': 2, 'High': 3}
        df["Risk_Num"] = df["Risk"].map(risk_map)

        fig, ax = plt.subplots(figsize=(6, 3))
        ax.plot(df["Timestamp"], df["Risk_Num"], marker="o", linestyle="-", color="red")
        ax.set_ylim(0.5, 3.5)
        ax.set_yticks([1, 2, 3])
        ax.set_yticklabels(['Low', 'Moderate', 'High'])
        ax.set_title("Risk Level Over Time")
        ax.set_xlabel("Timestamp")
        ax.set_ylabel("Risk Level")
        ax.tick_params(axis='x', rotation=45)
        plt.tight_layout()

        df_display = df[["Temperature", "Duration", "Risk", "Timestamp"]]

        return risk, alert_msg, timestamp, summary_md, df_display, fig

    predict_btn.click(classify, inputs=[temp, duration],
                      outputs=[result, alert, ist_time, summary, history_table, plot])

    retrain_btn.click(retrain_model, outputs=[retrain_output])

demo.launch()