File size: 4,237 Bytes
7a7375f
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
960439c
 
 
 
 
 
 
 
 
7a7375f
960439c
 
 
 
 
7a7375f
960439c
7a7375f
960439c
 
 
 
 
 
 
 
 
 
7a7375f
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
import streamlit as st
import pandas as pd
import requests

# Set page configuration
st.set_page_config(page_title="SuperKart Sales Forecasting App", layout="centered")

# App title and description
st.title("SuperKart Sales Forecasting App")
st.write(
    "This tool predicts the sales revenue of products across SuperKart stores "
    "based on product and store attributes."
)

# Section for online prediction
st.subheader("Online Prediction (Single Product-Store Entry)")

# Collect user input for product & store features
product_weight = st.number_input("Product Weight (kg)", min_value=4.0, max_value=22.0, value=12.65, step=0.1)
product_sugar_content = st.selectbox("Sugar Content", ["Low Sugar", "Regular", "No Sugar", "Non-edible"])
product_allocated_area = st.number_input("Allocated Area (ratio)", min_value=0.004, max_value=0.298, value=0.068, step=0.001)
product_type = st.selectbox("Product Type", [
    "Fruits and Vegetables", "Snack Foods", "Dairy", "Canned", "Soft Drinks",
    "Health and Hygiene", "Baking Goods", "Bread", "Breakfast", "Frozen Foods",
    "Household", "Seafood", "Starchy Foods", "Meat", "Hard Drinks", "Others"
])
product_mrp = st.number_input("Product MRP", min_value=31.0, max_value=266.0, value=147.0, step=1.0)

store_id = st.selectbox("Store ID", ["OUT001","OUT002","OUT003","OUT004"])
store_establishment_year = st.number_input("Store Establishment Year", min_value=1987, max_value=2025, value=2002, step=1)
store_size = st.selectbox("Store Size", ["High", "Medium", "Low"])
store_location_city_type = st.selectbox("Store City Type", ["Tier 1", "Tier 2", "Tier 3"])
store_type = st.selectbox("Store Type", ["Supermarket Type1", "Supermarket Type2", "Supermarket Type3", "Food Mart"])

# Input DataFrame with EXACT column names as training
input_data = pd.DataFrame([{
    "Product_Weight": product_weight,
    "Product_Sugar_Content": product_sugar_content,
    "Product_Allocated_Area": product_allocated_area,
    "Product_Type": product_type,
    "Product_MRP": product_mrp,
    "Store_Id": "store_id",
    "Store_Establishment_Year": store_establishment_year,
    "Store_Size": store_size,
    "Store_Location_City_Type": store_location_city_type,
    "Store_Type": store_type
}])

# Make prediction when "Forecast Sales" is clicked
if st.button("Forecast Sales"):
    try:
        response = requests.post(
            "https://nsa9-ProductStoreSalesBackend.hf.space/v1/forecast",  # Flask backend endpoint
            json=input_data.to_dict(orient="records")[0]
        )
        if response.status_code == 200:
            # First, get the JSON data
            response_json = response.json()
            # Then, check if the key exists before trying to access it
            if "Predicted Sales (in dollars)" in response_json:
                prediction = response_json.get("Predicted Sales (in dollars)")
                st.success(f"Predicted Sales Revenue: ${prediction:,.2f}")
            else:
                st.error("Invalid response format from backend. The expected key 'Predicted Sales (in dollars)' was not found.")
                st.write("Full response from backend:", response_json)
        else:
            st.error(f"Error from backend: {response.status_code}")
            st.write("Full response text:", response.text)
    except requests.exceptions.RequestException as e:
        st.error(f"Request failed: {e}")

# Section for batch prediction
st.subheader("Batch Prediction (Upload CSV)")

uploaded_file = st.file_uploader("Upload a CSV file with multiple product-store entries", type=["csv"])

if uploaded_file is not None and st.button("Predict Batch"):
    try:
        response = requests.post(
            "https://nsa9-ProductStoreSalesBackend.hf.space/v1/forecastbatch",  # Flask backend batch endpoint
            files={"file": uploaded_file}
        )
        if response.status_code == 200:
            predictions = response.json()
            st.success("Batch predictions completed!")
            st.write(pd.DataFrame(predictions, index=["Predicted Sales"]))  # Display nicely as a table
        else:
            st.error(f"Error from backend: {response.status_code}")
    except Exception as e:
        st.error(f"Batch request failed: {e}")