/Wine-Quality

Red Wine Quality test

Primary LanguageJupyter Notebook

Which machine learning algorithm will enable the most accurate prediction of wine quality from its physicochemical properties? What physicochemical properties of red wine have the highest impact on its quality?

In the following project, I applied three different machine learning algorithms to predict the quality of a wine. The dataset I used for the project is called Wine Quality Data Set (specifically the “winequality-red.csv” file), taken from the UCI Machine Learning Repository.

The dataset contains 1,599 observations and 12 attributes related to the red variants of the Portuguese “Vinho Verde” wine. Each row describes the physicochemical properties of one bottle of wine. The first 11 independent variables display numeric information about these characteristics, and the last dependent variable reveals the quality of the wine on a scale from 0 (bad quality wine) to 10 (good quality wine) based on sensory data. Since the outcome variable is ordinal, I chose logistic regression, decision trees, and random forest classification algorithms to answer the following questions:

Comparison of the logistic regression, decision tree, random forest, naive bayes models to predict red wine quality in Python

Methodology

For this project, I followed the following steps.

  1. Import the dataset:

In this step, I import the dataset into the Rstudio and formated the outcome variable. 2. Performed an exploratory data analysis (EDA):

First, I developed a descriptive statistic analysis to examine the independent variables by studying the boxplots and histogram plots of each variable. Additionally, I analyzed the dependent variable by creating a frequency plot of the variable. Finally, perform a bivariate analysis to understand the relationship between the variables. 3. Data preparation:

For this part of the project, I focused on finding and asses the missing and outliers values in the data. In other words, this step was to prepare the data for the prediction models. 4. Modeling:

The next step of the project was to develop three regression models that will be able to predict the dependent variable. First, I proceed to split the data into train and test set. Further, I train a logistic regression, decision tree, and random forest models. 5. Variable importance:

Finally, the last step was to gather the essential variables from the model that reveal the highest accuracy.