-
-
Notifications
You must be signed in to change notification settings - Fork 213
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Added README.md for Student Stress Levels Detection project
- Loading branch information
1 parent
92bc465
commit c382b65
Showing
2 changed files
with
71 additions
and
0 deletions.
There are no files selected for viewing
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,71 @@ | ||
## Student Stress Levels Detection | ||
|
||
### 🎯 **Goal** | ||
|
||
To understand the influence of the headache, study load, academic performance etc on students stress level. | ||
|
||
### 🧵 **Dataset** | ||
|
||
https://www.kaggle.com/datasets/samyakb/student-stress-factors/data | ||
|
||
### 🧾 **Description** | ||
|
||
By using Data Analysis, Data Visualization and then applying various Regression Algorithms from Machine Learning to predict a students stress level. | ||
|
||
### 🧮 **What I had done!** | ||
|
||
1. Checked the shape of dataset, types of columns and basic statistics | ||
2. Then checked the histplots and boxplot of all the features | ||
3. Then checked distribution of stress level | ||
4. Then checked reg plots of other features with stress level | ||
5. Then checked pair plots and correlation heatmap of all the features | ||
6. Then divided the dataset into features and target and normalised features and splitted dataset into training and testing sets | ||
7. Then trained on each model and checked the MAE and R2 on testing dataset | ||
8. Then selected Decision Tree Regressor and did hyper parameter tuning on that and got the best model and saved it. | ||
|
||
### 🚀 **Models Implemented** | ||
|
||
- Linear Regression | ||
- Decision Tree | ||
- Random Forest | ||
- Gradient Boosting | ||
- Support Vector Regressor | ||
- XGBoost Regressor | ||
|
||
### 📚 **Libraries Needed** | ||
|
||
- matplotlib | ||
- seaborn | ||
- numpy | ||
- pandas | ||
- scikit_learn | ||
- xgboost | ||
|
||
### 📊 **Exploratory Data Analysis Results** | ||
|
||
![Box Plots](./Images/box_plots.png) | ||
![Reg Plots](./Images/reg_plots.png) | ||
![Stress KDE](./Images/stress_level_kde.png) | ||
|
||
### 📈 **Performance of the Models based on the Accuracy Scores** | ||
|
||
| Model | R^2 Score | MAE | | ||
|-------------------------|-----------|------| | ||
| Linear Regression | 0.23 | 1.01 | | ||
| Decision Tree | 0.91 | 0.13 | | ||
| Random Forest | 0.90 | 0.18 | | ||
| Gradient Boosting | 0.74 | 0.55 | | ||
| Support Vector Regressor| 0.60 | 0.60 | | ||
| XGBoost Regressor | 0.91 | 0.13 | | ||
|
||
|
||
### 📢 **Conclusion** | ||
|
||
Both Decision Tree and XGBoost have similar performance in terms of R^2 score and MAE. | ||
Selecting **Decision Tree Regressor** as its easier to interpret as you can visualize the tree and understand the decision-making process. | ||
|
||
### ✒️ **Your Signature** | ||
|
||
K Om Senapati <br /> | ||
[![GitHub](https://img.shields.io/badge/GitHub-kom--senapati-blue?style=flat&logo=github)](https://github.com/kom-senapati) | ||
[![Twitter](https://img.shields.io/badge/Twitter-kom__senapati-blue?style=flat&logo=twitter)](https://twitter.com/kom_senapati) |