- About The Project
- About the Data
- Technology Stack
- Getting Started
- Usage and Configuration
- Contributing
- License
- Contact
- Acknowledgements
The Bank Customer Salary Prediction app uses deep learning to predict the estimated annual salary of a bank customer based on their demographic and account-related information. The app is powered by a deep learning Artificial Neural Network (ANN) Regression model that analyzes various features such as customer age, account balance, credit score, and services availed by the customer. Built with TensorFlow for the model and Streamlit for the front-end web application, the app offers an interactive interface to predict customer salary in real-time.
The app allows users to input a customer's data and instantly receive a prediction of their estimated salary. The project also includes preprocessing steps like encoding categorical variables and scaling numerical inputs.
This dataset contains details of bank customers, and it is used to predict the estimated salary of each customer. The dataset is based on a sample of bank customers and contains various demographic and account-related features. It has been cleaned and processed for machine learning applications. The target variable, EstimatedSalary
, represents the predicted salary of each customer.
- CustomerId: Unique identifier for each customer
- Surname: Customer surname
- CreditScore: Credit score of the customer
- Geography: Country of residence (e.g., France, Spain, Germany)
- Gender: Gender of the customer (Male or Female)
- Age: Age of the customer
- Tenure: Number of years the customer has been with the bank
- Balance: Account balance of the customer
- NumOfProducts: Number of products the customer is using (e.g., checking account, savings account)
- HasCrCard: Whether the customer has a credit card or not
- IsActiveMember: Whether the customer is an active member or not
- EstimatedSalary: The target variable (Estimated annual salary of the customer)
The target variable is EstimatedSalary
, which represents the predicted salary of the customer. This is a regression task, where the model aims to predict a continuous value, the estimated salary of the customer based on the provided features.
You can download the dataset from Kaggle here:
Bank Customer Churn Prediction Dataset
- Python (Programming Language)
- Streamlit (Web Framework)
- TensorFlow (Deep Learning Library)
- Scikit-learn (Machine Learning Library)
- Pandas (Data Manipulation)
- NumPy (Numerical Computing)
- Pickle (Model Serialization)
To get started with this project locally, you’ll need Python 3.8+ installed on your machine along with some necessary Python packages. You can either clone the repository and install dependencies manually or use Docker for an isolated environment.
-
Clone the repository:
- Open your terminal or command prompt.
- Navigate to the directory where you want to install the project.
- Run the following command to clone the GitHub repository:
git clone https://github.com/shubhamprajapati7748/Bank-Customer-Churn-Prediction.git
-
Create a Virtual Environment (Optional)
- It's a good practice to create a virtual environment to manage project dependencies. Run the following command:
conda create -p <Environment_Name> python==<python version> -y
- It's a good practice to create a virtual environment to manage project dependencies. Run the following command:
-
Activate the Virtual Environment (Optional)
- Activate the virtual environment based on your operating system:
conda activate <Environment_Name>/
- Activate the virtual environment based on your operating system:
-
Install Dependencies
- Navigate to the project directory:
cd [project_directory]
- Run the following command to install project dependencies:
pip install -r requirements.txt
- Navigate to the project directory:
-
Run the Project
streamlit run app.py
-
Access the Project
- Visit
http://localhost:8501
in your browser to use the app.
- Visit
-
Pull the Docker image from DockerHub (if available):
docker pull shubhamprajapati7748/salary-prediction-app:latest
-
Run the app inside the container:
docker run -p 8501:8501 shubhamprajapati7748/salary-prediction-app:latest
-
Visit
http://localhost:8501
in your browser to use the app.
- Enter Customer Information: Input fields for age, gender, geography, and other demographic and account details.
- Click "Predict Churn": After entering the data, click the prediction button to view the likelihood of churn and whether the customer is likely to churn or not.
- Prediction Results: The app will display the churn probability along with a clear message about the likelihood of churn.
You can modify the Artifacts/
directory to point to your own trained models, encoders, and scaler files. Make sure the model and encoders are trained and saved in compatible formats (e.g., .h5
, .pkl
).
We welcome contributions to improve this project! Whether you are fixing bugs, adding features, or improving documentation, feel free to fork the repository and submit a pull request.
- Fork the repo.
- Create a new branch (
git checkout -b feature-name
). - Make your changes.
- Commit your changes (
git commit -am 'Add feature'
). - Push to your branch (
git push origin feature-name
). - Create a new Pull Request.
Distributed under the MIT License. See LICENSE
for more information.
Shubham Prajapati - @[email protected]
- TensorFlow: For providing the machine learning framework to train the predictive model.
- Streamlit: For creating the interactive web application.
- Scikit-learn: For preprocessing utilities such as scaling and encoding.
- Kaggle: For the inspiration behind the dataset, which is similar to the dataset used in this project.