File size: 3,799 Bytes
ef01245
 
 
 
 
 
 
 
 
873334a
08b3519
873334a
 
 
 
ef01245
 
 
 
 
 
 
 
 
 
ba7dd0e
ef01245
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1651476
 
 
 
 
ef01245
 
 
 
 
 
 
 
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

import streamlit as st
import requests
import json
import pandas as pd
import os # Import os to access environment variables if needed later

# Define the URL of your deployed backend API on Hugging Face Spaces
# The URL format is typically https://<your-username>-<your-space-name>.hf.space
# Replace with your actual Space URL
# Assuming the backend space name is 'SuperKartBackendSC'
# You need to manually replace <your-username> with your actual Hugging Face username
HF_USERNAME = os.getenv("HF_USERNAME", "sumachakkingal") # Get username from environment variable or use placeholder
BACKEND_SPACE_NAME = "SuperKartBackendSC"
BACKEND_API_URL = f"https://{HF_USERNAME}-{BACKEND_SPACE_NAME}.hf.space/predict"


st.title("SuperKart Sales Prediction Frontend")

st.write("Enter the product and store details to get a sales prediction.")

# Create input fields for the features
# Ensure the keys match the column names expected by your Flask app
product_weight = st.number_input("Product Weight", min_value=0.0)
product_sugar_content = st.selectbox("Product Sugar Content", ['Low Sugar', 'Regular', 'No Sugar'])
product_allocated_area = st.number_input("Product Allocated Area", min_value=0.00)
product_type = st.selectbox("Product Type", ['Frozen Foods', 'Dairy', 'Canned', 'Baking Goods', 'Health and Hygiene', 'Snack Foods', 'Meat', 'Household', 'Hard Drinks', 'Fruits and Vegetables', 'Breads', 'Soft Drinks', 'Breakfast', 'Others', 'Starchy Foods', 'Seafood'])
product_mrp = st.number_input("Product MRP", min_value=0.0)
store_id = st.selectbox("Store ID", ['OUT004', 'OUT001', 'OUT003', 'OUT002'])
store_size = st.selectbox("Store Size", ['Medium', 'High', 'Small'])
store_location_city_type = st.selectbox("Store Location City Type", ['Tier 2', 'Tier 1', 'Tier 3'])
store_type = st.selectbox("Store Type", ['Supermarket Type2', 'Departmental Store', 'Supermarket Type1', 'Food Mart'])
store_establishment_year = st.number_input("Store Establishment Year", min_value=1985, max_value=2024)

# Calculate Store_Age (assuming current year is 2024)
current_year = 2024
store_age = current_year - store_establishment_year


# Create a dictionary with the input data
# The keys must match the column names used for training and expected by the Flask app
input_data = {
    "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_Size": store_size,
    "Store_Location_City_Type": store_location_city_type,
    "Store_Type": store_type,
    "Store_Age": store_age # Include Store_Age as it's used by the model
}

# Create a button to trigger the prediction
if st.button("Predict Sales"):
    try:
        # Send the input data to the backend API
        response = requests.post(BACKEND_API_URL, json=input_data)

        # Check if the request was successful
        if response.status_code == 200:
            prediction_result = response.json()
            predicted_sales = prediction_result.get("prediction")
            if predicted_sales is not None:
                st.success(f"Predicted Product Store Sales Total: {predicted_sales:.2f}")
            else:
                st.error("Could not retrieve a valid prediction from the backend.")
            #st.success(f"Predicted Product Store Sales Total: {predicted_sales:.2f}")
        else:
            st.error(f"Error: Could not get prediction from the backend. Status code: {response.status_code}")
            st.error(f"Response: {response.text}")

    except requests.exceptions.RequestException as e:
        st.error(f"Error connecting to the backend API: {e}")
    except Exception as e:
        st.error(f"An unexpected error occurred: {e}")