kapilmika commited on
Commit
daefc82
·
verified ·
1 Parent(s): 0e2d045

Upload folder using huggingface_hub

Browse files
Files changed (3) hide show
  1. Dockerfile +8 -13
  2. app.py +68 -0
  3. requirements.txt +4 -3
Dockerfile CHANGED
@@ -1,21 +1,16 @@
 
1
  FROM python:3.9-slim
2
 
 
3
  WORKDIR /app
4
 
5
- RUN apt-get update && apt-get install -y \
6
- build-essential \
7
- curl \
8
- software-properties-common \
9
- git \
10
- && rm -rf /var/lib/apt/lists/*
11
-
12
- COPY requirements.txt ./
13
- COPY src/ ./src/
14
 
 
15
  RUN pip3 install -r requirements.txt
16
 
17
- EXPOSE 8501
18
-
19
- HEALTHCHECK CMD curl --fail http://localhost:8501/_stcore/health
20
 
21
- ENTRYPOINT ["streamlit", "run", "src/streamlit_app.py", "--server.port=8501", "--server.address=0.0.0.0"]
 
1
+ # Use a minimal base image with Python 3.9 installed
2
  FROM python:3.9-slim
3
 
4
+ # Set the working directory inside the container to /app
5
  WORKDIR /app
6
 
7
+ # Copy all files from the current directory on the host to the container's /app directory
8
+ COPY . .
 
 
 
 
 
 
 
9
 
10
+ # Install Python dependencies listed in requirements.txt
11
  RUN pip3 install -r requirements.txt
12
 
13
+ # Define the command to run the Streamlit app on port 8501 and make it accessible externally
14
+ CMD ["streamlit", "run", "app.py", "--server.port=8501", "--server.address=0.0.0.0", "--server.enableXsrfProtection=false"]
 
15
 
16
+ # NOTE: Disable XSRF protection for easier external access in order to make batch predictions
app.py ADDED
@@ -0,0 +1,68 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import streamlit as st
2
+ import pandas as pd
3
+ import requests
4
+
5
+ # Set the title of the Streamlit app
6
+ st.title("SupreKart Product Sales Revenue Price Prediction")
7
+
8
+ # Section for online prediction
9
+ st.subheader("Online Revenue Prediction")
10
+
11
+ # List of product types
12
+ product_types = [
13
+ "Fruits and Vegetables", "Snack Foods", "Frozen Foods", "Dairy", "Household",
14
+ "Baking Goods", "Canned", "Health and Hygiene", "Meat", "Soft Drinks",
15
+ "Breads", "Hard Drinks", "Starchy Foods", "Breakfast", "Seafood", "Others"
16
+ ]
17
+
18
+ # User input fields
19
+ Product_Weight = st.number_input("Product Weight (in Kg)", min_value=0.0, max_value=50.0, step=1.0, value=10.0)
20
+ Product_Sugar_Content = st.selectbox("Product Sugar Content", ["Low Sugar", "Regular", "No Sugar", "reg"])
21
+ Product_Allocated_Area = st.number_input("Product Allocated Area", min_value=0.004, max_value=0.298, step=0.001, value=0.031)
22
+ Product_Type = st.selectbox("Product Type", product_types)
23
+ Product_MRP = st.number_input("Product MRP", min_value=0.10, max_value=500.00, step=0.5, value=30.00)
24
+ Store_Id = st.selectbox("Store ID", ["OUT001", "OUT002", "OUT003", "OUT004"])
25
+ Store_Establishment_Year = st.number_input("Store Establishment Year", min_value=1900, max_value=2025, step=1, value=1987)
26
+ Store_Size = st.selectbox("Store Size", ["Medium", "High", "Small"])
27
+ Store_Location_City_Type = st.selectbox("Store Location City Type", ["Tier 1", "Tier 2", "Tier 3"])
28
+ Store_Type = st.selectbox("Store Type", ["Supermarket Type1", "Supermarket Type2", "Departmental Store", "Food Mart"])
29
+
30
+ # Convert user input into a DataFrame
31
+ input_data = pd.DataFrame([{
32
+ 'Product_Weight': Product_Weight,
33
+ 'Product_Sugar_Content': Product_Sugar_Content,
34
+ 'Product_Allocated_Area': Product_Allocated_Area,
35
+ 'Product_Type': Product_Type,
36
+ 'Product_MRP': Product_MRP,
37
+ 'Store_Id':Store_Id,
38
+ 'Store_Establishment_Year':Store_Establishment_Year,
39
+ 'Store_Size': Store_Size,
40
+ 'Store_Location_City_Type': Store_Location_City_Type,
41
+ 'Store_Type': Store_Type
42
+ }])
43
+
44
+ # Make prediction when the "Predict" button is clicked
45
+ if st.button("Predict"):
46
+ response = requests.post("https://kapilmika-SupreKartPredictionBackend.hf.space/v1/revenue", json=input_data.to_dict(orient='records')[0]) # Send data to Flask API
47
+ if response.status_code == 200:
48
+ prediction = response.json()['Predicted Revenue (in dollars)']
49
+ st.success(f"Predicted Rental Price (in dollars): {prediction}")
50
+ else:
51
+ st.error("Error making prediction.")
52
+
53
+ # Section for batch prediction
54
+ st.subheader("Batch Prediction")
55
+
56
+ # Allow users to upload a CSV file for batch prediction
57
+ uploaded_file = st.file_uploader("Upload CSV file for batch prediction", type=["csv"])
58
+
59
+ # Make batch prediction when the "Predict Batch" button is clicked
60
+ if uploaded_file is not None:
61
+ if st.button("Predict Batch"):
62
+ response = requests.post("https://kapilmika-SupreKartPredictionBackend.hf.space/v1/revenuebatch", files={"file": uploaded_file}) # Send file to Flask API
63
+ if response.status_code == 200:
64
+ predictions = response.json()
65
+ st.success("Batch predictions completed!")
66
+ st.write(predictions) # Display the predictions
67
+ else:
68
+ st.error("Error making batch prediction.")
requirements.txt CHANGED
@@ -1,3 +1,4 @@
1
- altair
2
- pandas
3
- streamlit
 
 
1
+ pandas==2.2.2
2
+ numpy==2.0.2
3
+ requests==2.28.1
4
+ streamlit==1.43.2