Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/abhash-rai/regression-car-price-prediction
This repository contains my first complete data science project from web scrapping for data to data preprocessing, cleaning, exploratory data analysis, model training and deployment.
https://github.com/abhash-rai/regression-car-price-prediction
data data-science data-visualization eda exploratory-data-analysis machine-learning neural-network prediction prediction-model regression
Last synced: about 2 months ago
JSON representation
This repository contains my first complete data science project from web scrapping for data to data preprocessing, cleaning, exploratory data analysis, model training and deployment.
- Host: GitHub
- URL: https://github.com/abhash-rai/regression-car-price-prediction
- Owner: abhash-rai
- Created: 2022-08-20T05:46:18.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2022-08-20T06:31:04.000Z (over 2 years ago)
- Last Synced: 2023-10-16T22:48:15.405Z (about 1 year ago)
- Topics: data, data-science, data-visualization, eda, exploratory-data-analysis, machine-learning, neural-network, prediction, prediction-model, regression
- Language: Jupyter Notebook
- Homepage:
- Size: 13.5 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Regression: Predictions for car prices
This repository contains my first complete data science project from web scrapping for data to data preprocessing, cleaning and model training.If you wish to continue without reading everything, open "Scripts/ModelTraining.ipynb" which is notebook(jupyter) of the model training stage.
It has links to all other scripts(python-web scrapping), csv files(dataset) and notebooks(data preprocessing and exploratory data anaysis).Tools used:
1. pandas
2. matplotlib
3. seaborn
4. scipy
5. regex
6. numpy
7. missingno
8. pickle
9. sklearn
10. beautifulsoup4
11. jupyter labThe webscrapped data was very messey and took a lot of time and coding to get it cleaned. Hence, in addition to the web scrapper(python script), there are 3 different notebook(jupyter) for data cleaning, exploratory data analysis and model training respectively. Read below for the directory of each notebooks.
This project consists of 4 parts:
Web scrapping(Folder --> Scripts/Step1-WebScrapper) :
1. Information about cars were scrapped from "ccarprice.com/au/" and stored as a csv file in tabular form.
For the web scrapper(go to) --> Scripts/Step1-WebScrapper/scrapper.py
2. Price of cars in Australian dollars is the target feature and to predict it, there are many other independent features.
For the unprocessed csv(go to) --> Scripts/Step1-WebScrapper/car_prices_australia.csvData preprocessing and cleaning (Folder --> Scripts/Step2-DataCleaning) :
1. Step 1 (Folder --> Scripts/Step2-DataCleaning/Step1) :
In step 1 :
a. Dataset is imported (Scripts/Step1-WebScrapper/car_prices_australia.csv).
b. Duplicates are handeled.
c. Feature selection is performed.
d. Features are modified; the structural errors are fixed and hence turned into usable features.
e. Data types are properly set for each features to its accurate one.
f. Columns names are renamed.
g. Null values are dealt with by using median or mode imputation.
h. With the help of visualization tools (matplotlib & seaborn), outiers are figured out and dealt with by either trimming it or using quantile based flooring and capping.
i. Unique values with very low frequency of categorical and interval(numerical) are either removed or replaced.
j. Processed and cleaned dataset is saved (Scripts/Step2-DataCleaning/Step1/step1-Completed.csv)
For the notebook(jupyter) of step 1(go to) --> Scripts/Step2-DataCleaning/Step1/Step1-FixingStructuralErrors.ipynb
For the step 1 completed csv(go to) --> Scripts/Step2-DataCleaning/Step1/step1-Completed.csv
Hence, the dataset as result of step 1 is clean and can be directly used to train model, but exploratory data analysis is done in step 2 to get to know the dataset better and possibly figure out any errors in the dataset if there are any.
2. Step 2 (Folder --> Scripts/Step2-DataCleaning/Step2) :
In step 2 of data preprocessing :
a.
b. Exploratory data analysis is performed,
c. feature distribution and correlations are visualized.
d. The features distribution are still skewed so, the best transformation(QuantileTransformer) is figured out which will be used later in model training.
For the notebook(jupyter) of step 2(go to) --> Scripts/Step2-DataCleaning/Step2/Step2-EDA.ipynb
For the step 2 completed csv(go to) --> Scripts/Step2-DataCleaning/Step2/Step2-Completed.csv
Model Training:
For the notebook(jupyter) of model training(go to) --> Scripts/ModelTraining.ipynb
1. The names of features and any nominal values are stored for future use.
For the stored file(go to) --> Scripts/Models/Feature-Options/options.txt1. In this stage, numeric features are transformed using "QuantileTransformer" from sklearn which are then fed into several supervised regression models for choosing the best one. The tranformer object of the test dataset are stored using "pickle"; a python library which are used to perform inverse transformation.
For saved transformer object of independent variables(go to) --> Scripts/Models/Independent_Features_QuantileTransformer.pkl
For saved transformer object of target variable(go to) --> Scripts/Models/Target_Feature_QuantileTransformer.pkl
2. Hyperparameters tuning of the choosen model(RandomForestRegressor) is performed using "RandomizedSearchCV" from sklearn. The tuned model is stored using "pickle" again.
For the saved model(go to) --> Scripts/Models/Model.pkl3. A scatter plot of actual unsclaled target values vs predicted(which is also inverse transformed) values is created.