The objective of this notebook is to present an extensive analysis of the IBM Customer Churn Dataset and to predict the customer churn rate.
- Dataset mostly has categorical variables
- Data is not normally distributed, performed Nonparametric Statistical tests
- Performed statistical hypothesis test to check correlation , multicollinearity
- Imbalanced dataset, did experiment with different sampling techniques(e.g stratifying, imblearn - SMOTE etc)
- Tuned Hyperparameters using Optuna
- Performed single level Stacking Ensemble with Triple Gradient boosting algorithms and classic algorithms
- Number of months the customer has stayed with the company (tenure) and the contract term of the customer (contract) are the most important features that have strong correlation with churn of the customer
- Results from statiscial hypotheses testing reflects similarity with model feature importance
- With 80/20 train/test split triple boosting stacking ensemble model achieved an AUC of ~0.85
optuna==2.10.0
xgboost==0.90
catboost==1.0.1
lightgbm==2.2.3
plotly==4.4.1
scipy==1.7.1
scikit-learn==0.22.2.post1