You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1072 lines
67 KiB

{
"cells": [
{
"cell_type": "markdown",
"metadata": {},
"source": [
"___\n",
"\n",
"<a href='http://www.pieriandata.com'><img src='../Pierian_Data_Logo.png'/></a>\n",
"___\n",
"<center><em>Copyright by Pierian Data Inc.</em></center>\n",
"<center><em>For more information, visit us at <a href='http://www.pieriandata.com'>www.pieriandata.com</a></em></center>"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"# Linear Regression with SciKit-Learn\n",
"\n",
"We saw how to create a very simple best fit line, but now let's greatly expand our toolkit to start thinking about the considerations of overfitting, underfitting, model evaluation, as well as multiple features!"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Imports"
]
},
{
"cell_type": "code",
"execution_count": 2,
"metadata": {},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
"C:\\ProgramData\\Anaconda3\\lib\\site-packages\\statsmodels\\tools\\_testing.py:19: FutureWarning: pandas.util.testing is deprecated. Use the functions in the public API at pandas.testing instead.\n",
" import pandas.util.testing as tm\n"
]
}
],
"source": [
"import numpy as np\n",
"import pandas as pd\n",
"import matplotlib.pyplot as plt\n",
"import seaborn as sns"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Sample Data\n",
"\n",
"This sample data is from ISLR. It displays sales (in thousands of units) for a particular product as a function of advertising budgets (in thousands of dollars) for TV, radio, and newspaper media."
]
},
{
"cell_type": "code",
"execution_count": 3,
"metadata": {},
"outputs": [],
"source": [
"df = pd.read_csv(\"Advertising.csv\")"
]
},
{
"cell_type": "code",
"execution_count": 4,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>TV</th>\n",
" <th>radio</th>\n",
" <th>newspaper</th>\n",
" <th>sales</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>230.1</td>\n",
" <td>37.8</td>\n",
" <td>69.2</td>\n",
" <td>22.1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>44.5</td>\n",
" <td>39.3</td>\n",
" <td>45.1</td>\n",
" <td>10.4</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>17.2</td>\n",
" <td>45.9</td>\n",
" <td>69.3</td>\n",
" <td>9.3</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>151.5</td>\n",
" <td>41.3</td>\n",
" <td>58.5</td>\n",
" <td>18.5</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>180.8</td>\n",
" <td>10.8</td>\n",
" <td>58.4</td>\n",
" <td>12.9</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" TV radio newspaper sales\n",
"0 230.1 37.8 69.2 22.1\n",
"1 44.5 39.3 45.1 10.4\n",
"2 17.2 45.9 69.3 9.3\n",
"3 151.5 41.3 58.5 18.5\n",
"4 180.8 10.8 58.4 12.9"
]
},
"execution_count": 4,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df.head()"
]
},
{
"cell_type": "code",
"execution_count": 5,
"metadata": {},
"outputs": [],
"source": [
"# Everything BUT the sales column\n",
"X = df.drop('sales',axis=1)"
]
},
{
"cell_type": "code",
"execution_count": 6,
"metadata": {},
"outputs": [],
"source": [
"y = df['sales']"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## SciKit Learn \n",
"\n",
"---"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Polynomial Regression"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"**From Preprocessing, import PolynomialFeatures, which will help us transform our original data set by adding polynomial features**\n",
"\n",
"We will go from the equation in the form (shown here as if we only had one x feature):\n",
"\n",
"$$\\hat{y} = \\beta_0 + \\beta_1x_1 + \\epsilon $$\n",
"\n",
"and create more features from the original x feature for some *d* degree of polynomial.\n",
"\n",
"$$\\hat{y} = \\beta_0 + \\beta_1x_1 + \\beta_1x^2_1 + ... + \\beta_dx^d_1 + \\epsilon$$\n",
"\n",
"Then we can call the linear regression model on it, since in reality, we're just treating these new polynomial features x^2, x^3, ... x^d as new features. Obviously we need to be careful about choosing the correct value of *d* , the degree of the model. Our metric results on the test set will help us with this!\n",
"\n",
"**The other thing to note here is we have multiple X features, not just a single one as in the formula above, so in reality, the PolynomialFeatures will also take *interaction* terms into account for example, if an input sample is two dimensional and of the form [a, b], the degree-2 polynomial features are [1, a, b, a^2, ab, b^2].**"
]
},
{
"cell_type": "code",
"execution_count": 7,
"metadata": {},
"outputs": [],
"source": [
"from sklearn.preprocessing import PolynomialFeatures"
]
},
{
"cell_type": "code",
"execution_count": 8,
"metadata": {},
"outputs": [],
"source": [
"polynomial_converter = PolynomialFeatures(degree=2,include_bias=False)"
]
},
{
"cell_type": "code",
"execution_count": 9,
"metadata": {},
"outputs": [],
"source": [
"# Converter \"fits\" to data, in this case, reads in every X column\n",
"# Then it \"transforms\" and ouputs the new polynomial data\n",
"poly_features = polynomial_converter.fit_transform(X)"
]
},
{
"cell_type": "code",
"execution_count": 10,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"(200, 9)"
]
},
"execution_count": 10,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"poly_features.shape"
]
},
{
"cell_type": "code",
"execution_count": 11,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"(200, 3)"
]
},
"execution_count": 11,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"X.shape"
]
},
{
"cell_type": "code",
"execution_count": 12,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"TV 230.1\n",
"radio 37.8\n",
"newspaper 69.2\n",
"Name: 0, dtype: float64"
]
},
"execution_count": 12,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"X.iloc[0]"
]
},
{
"cell_type": "code",
"execution_count": 13,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"array([2.301000e+02, 3.780000e+01, 6.920000e+01, 5.294601e+04,\n",
" 8.697780e+03, 1.592292e+04, 1.428840e+03, 2.615760e+03,\n",
" 4.788640e+03])"
]
},
"execution_count": 13,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"poly_features[0]"
]
},
{
"cell_type": "code",
"execution_count": 14,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"array([230.1, 37.8, 69.2])"
]
},
"execution_count": 14,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"poly_features[0][:3]"
]
},
{
"cell_type": "code",
"execution_count": 15,
"metadata": {
"scrolled": true
},
"outputs": [
{
"data": {
"text/plain": [
"array([52946.01, 1428.84, 4788.64])"
]
},
"execution_count": 15,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"poly_features[0][:3]**2"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"The interaction terms $$x_1 \\cdot x_2 \\text{ and } x_1 \\cdot x_3 \\text{ and } x_2 \\cdot x_3 $$"
]
},
{
"cell_type": "code",
"execution_count": 16,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"8697.779999999999"
]
},
"execution_count": 16,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"230.1*37.8"
]
},
{
"cell_type": "code",
"execution_count": 17,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"15922.92"
]
},
"execution_count": 17,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"230.1*69.2"
]
},
{
"cell_type": "code",
"execution_count": 18,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"2615.7599999999998"
]
},
"execution_count": 18,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"37.8*69.2"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Train | Test Split\n",
"\n",
"Make sure you have watched the Machine Learning Overview videos on Supervised Learning to understand why we do this step"
]
},
{
"cell_type": "code",
"execution_count": 19,
"metadata": {},
"outputs": [],
"source": [
"from sklearn.model_selection import train_test_split"
]
},
{
"cell_type": "code",
"execution_count": 20,
"metadata": {},
"outputs": [],
"source": [
"# random_state: \n",
"# https://stackoverflow.com/questions/28064634/random-state-pseudo-random-number-in-scikit-learn\n",
"X_train, X_test, y_train, y_test = train_test_split(poly_features, y, test_size=0.3, random_state=101)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Model for fitting on Polynomial Data\n",
"\n",
"#### Create an instance of the model with parameters"
]
},
{
"cell_type": "code",
"execution_count": 22,
"metadata": {},
"outputs": [],
"source": [
"from sklearn.linear_model import LinearRegression"
]
},
{
"cell_type": "code",
"execution_count": 23,
"metadata": {},
"outputs": [],
"source": [
"model = LinearRegression(fit_intercept=True)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Fit/Train the Model on the training data\n",
"\n",
"**Make sure you only fit to the training data, in order to fairly evaluate your model's performance on future data**"
]
},
{
"cell_type": "code",
"execution_count": 24,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"LinearRegression(copy_X=True, fit_intercept=True, n_jobs=None, normalize=False)"
]
},
"execution_count": 24,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"model.fit(X_train,y_train)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"-----\n",
"\n",
"## Evaluation on the Test Set"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Calculate Performance on Test Set\n",
"\n",
"We want to fairly evaluate our model, so we get performance metrics on the test set (data the model has never seen before)."
]
},
{
"cell_type": "code",
"execution_count": 25,
"metadata": {},
"outputs": [],
"source": [
"test_predictions = model.predict(X_test)"
]
},
{
"cell_type": "code",
"execution_count": 26,
"metadata": {},
"outputs": [],
"source": [
"from sklearn.metrics import mean_absolute_error,mean_squared_error"
]
},
{
"cell_type": "code",
"execution_count": 27,
"metadata": {},
"outputs": [],
"source": [
"MAE = mean_absolute_error(y_test,test_predictions)\n",
"MSE = mean_squared_error(y_test,test_predictions)\n",
"RMSE = np.sqrt(MSE)"
]
},
{
"cell_type": "code",
"execution_count": 28,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"0.489679804480361"
]
},
"execution_count": 28,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"MAE"
]
},
{
"cell_type": "code",
"execution_count": 29,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"0.4417505510403426"
]
},
"execution_count": 29,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"MSE"
]
},
{
"cell_type": "code",
"execution_count": 30,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"0.6646431757269028"
]
},
"execution_count": 30,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"RMSE"
]
},
{
"cell_type": "code",
"execution_count": 31,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"14.022500000000003"
]
},
"execution_count": 31,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df['sales'].mean()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Comparison with Simple Linear Regression\n",
"\n",
"**Results on the Test Set (Note: Use the same Random Split to fairly compare!)**\n",
"\n",
"* Simple Linear Regression:\n",
" * MAE: 1.213\n",
" * RMSE: 1.516\n",
"\n",
"* Polynomial 2-degree:\n",
" * MAE: 0.4896\n",
" * RMSE: 0.664"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"---\n",
"---\n",
"## Choosing a Model\n",
"\n",
"### Adjusting Parameters\n",
"\n",
"Are we satisfied with this performance? Perhaps a higher order would improve performance even more! But how high is too high? It is now up to us to possibly go back and adjust our model and parameters, let's explore higher order Polynomials in a loop and plot out their error. This will nicely lead us into a discussion on Overfitting.\n",
"\n",
"Let's use a for loop to do the following:\n",
"\n",
"1. Create different order polynomial X data\n",
"2. Split that polynomial data for train/test\n",
"3. Fit on the training data\n",
"4. Report back the metrics on *both* the train and test results\n",
"5. Plot these results and explore overfitting"
]
},
{
"cell_type": "code",
"execution_count": 32,
"metadata": {},
"outputs": [],
"source": [
"# TRAINING ERROR PER DEGREE\n",
"train_rmse_errors = []\n",
"# TEST ERROR PER DEGREE\n",
"test_rmse_errors = []\n",
"\n",
"for d in range(1,10):\n",
" \n",
" # CREATE POLY DATA SET FOR DEGREE \"d\"\n",
" polynomial_converter = PolynomialFeatures(degree=d,include_bias=False)\n",
" poly_features = polynomial_converter.fit_transform(X)\n",
" \n",
" # SPLIT THIS NEW POLY DATA SET\n",
" X_train, X_test, y_train, y_test = train_test_split(poly_features, y, test_size=0.3, random_state=101)\n",
" \n",
" # TRAIN ON THIS NEW POLY SET\n",
" model = LinearRegression(fit_intercept=True)\n",
" model.fit(X_train,y_train)\n",
" \n",
" # PREDICT ON BOTH TRAIN AND TEST\n",
" train_pred = model.predict(X_train)\n",
" test_pred = model.predict(X_test)\n",
" \n",
" # Calculate Errors\n",
" \n",
" # Errors on Train Set\n",
" train_RMSE = np.sqrt(mean_squared_error(y_train,train_pred))\n",
" \n",
" # Errors on Test Set\n",
" test_RMSE = np.sqrt(mean_squared_error(y_test,test_pred))\n",
"\n",
" # Append errors to lists for plotting later\n",
" \n",
" \n",
" train_rmse_errors.append(train_RMSE)\n",
" test_rmse_errors.append(test_RMSE)"
]
},
{
"cell_type": "code",
"execution_count": 33,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"<matplotlib.legend.Legend at 0x168c0d109c8>"
]
},
"execution_count": 33,
"metadata": {},
"output_type": "execute_result"
},
{
"data": {
"image/png": "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\n",
"text/plain": [
"<Figure size 432x288 with 1 Axes>"
]
},
"metadata": {
"needs_background": "light"
},
"output_type": "display_data"
}
],
"source": [
"plt.plot(range(1,6),train_rmse_errors[:5],label='TRAIN')\n",
"plt.plot(range(1,6),test_rmse_errors[:5],label='TEST')\n",
"plt.xlabel(\"Polynomial Complexity\")\n",
"plt.ylabel(\"RMSE\")\n",
"plt.legend()"
]
},
{
"cell_type": "code",
"execution_count": 34,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"<matplotlib.legend.Legend at 0x168c1d7df08>"
]
},
"execution_count": 34,
"metadata": {},
"output_type": "execute_result"
},
{
"data": {
"image/png": "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\n",
"text/plain": [
"<Figure size 432x288 with 1 Axes>"
]
},
"metadata": {
"needs_background": "light"
},
"output_type": "display_data"
}
],
"source": [
"plt.plot(range(1,10),train_rmse_errors,label='TRAIN')\n",
"plt.plot(range(1,10),test_rmse_errors,label='TEST')\n",
"plt.xlabel(\"Polynomial Complexity\")\n",
"plt.ylabel(\"RMSE\")\n",
"plt.legend()"
]
},
{
"cell_type": "code",
"execution_count": 35,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"<matplotlib.legend.Legend at 0x168c41e5a88>"
]
},
"execution_count": 35,
"metadata": {},
"output_type": "execute_result"
},
{
"data": {
"image/png": "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\n",
"text/plain": [
"<Figure size 432x288 with 1 Axes>"
]
},
"metadata": {
"needs_background": "light"
},
"output_type": "display_data"
}
],
"source": [
"plt.plot(range(1,10),train_rmse_errors,label='TRAIN')\n",
"plt.plot(range(1,10),test_rmse_errors,label='TEST')\n",
"plt.xlabel(\"Polynomial Complexity\")\n",
"plt.ylabel(\"RMSE\")\n",
"plt.ylim(0,100)\n",
"plt.legend()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Finalizing Model Choice\n",
"\n",
"There are now 2 things we need to save, the Polynomial Feature creator AND the model itself. Let's explore how we would proceed from here:\n",
"\n",
"1. Choose final parameters based on test metrics\n",
"2. Retrain on all data\n",
"3. Save Polynomial Converter object\n",
"4. Save model"
]
},
{
"cell_type": "code",
"execution_count": 42,
"metadata": {},
"outputs": [],
"source": [
"# Based on our chart, could have also been degree=4, but \n",
"# it is better to be on the safe side of complexity\n",
"final_poly_converter = PolynomialFeatures(degree=3,include_bias=False)"
]
},
{
"cell_type": "code",
"execution_count": 43,
"metadata": {},
"outputs": [],
"source": [
"final_model = LinearRegression()"
]
},
{
"cell_type": "code",
"execution_count": 45,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"LinearRegression(copy_X=True, fit_intercept=True, n_jobs=None, normalize=False)"
]
},
"execution_count": 45,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"final_model.fit(final_poly_converter.fit_transform(X),y)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Saving Model and Converter"
]
},
{
"cell_type": "code",
"execution_count": 46,
"metadata": {},
"outputs": [],
"source": [
"from joblib import dump, load"
]
},
{
"cell_type": "code",
"execution_count": 49,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"['sales_poly_model.joblib']"
]
},
"execution_count": 49,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"dump(final_model, 'sales_poly_model.joblib') "
]
},
{
"cell_type": "code",
"execution_count": 50,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"['poly_converter.joblib']"
]
},
"execution_count": 50,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"dump(final_poly_converter,'poly_converter.joblib')"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Deployment and Predictions"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Prediction on New Data\n",
"\n",
"Recall that we will need to **convert** any incoming data to polynomial data, since that is what our model is trained on. We simply load up our saved converter object and only call **.transform()** on the new data, since we're not refitting to a new data set.\n",
"\n",
"**Our next ad campaign will have a total spend of 149k on TV, 22k on Radio, and 12k on Newspaper Ads, how many units could we expect to sell as a result of this?**"
]
},
{
"cell_type": "code",
"execution_count": 62,
"metadata": {},
"outputs": [],
"source": [
"loaded_poly = load('poly_converter.joblib')\n",
"loaded_model = load('sales_poly_model.joblib')"
]
},
{
"cell_type": "code",
"execution_count": 63,
"metadata": {},
"outputs": [],
"source": [
"campaign = [[149,22,12]]"
]
},
{
"cell_type": "code",
"execution_count": 64,
"metadata": {},
"outputs": [],
"source": [
"campaign_poly = loaded_poly.transform(campaign)"
]
},
{
"cell_type": "code",
"execution_count": 65,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"array([[1.490000e+02, 2.200000e+01, 1.200000e+01, 2.220100e+04,\n",
" 3.278000e+03, 1.788000e+03, 4.840000e+02, 2.640000e+02,\n",
" 1.440000e+02, 3.307949e+06, 4.884220e+05, 2.664120e+05,\n",
" 7.211600e+04, 3.933600e+04, 2.145600e+04, 1.064800e+04,\n",
" 5.808000e+03, 3.168000e+03, 1.728000e+03]])"
]
},
"execution_count": 65,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"campaign_poly"
]
},
{
"cell_type": "code",
"execution_count": 67,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"array([14.64501014])"
]
},
"execution_count": 67,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"final_model.predict(campaign_poly)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"-----\n",
"---"
]
}
],
"metadata": {
"anaconda-cloud": {},
"kernelspec": {
"display_name": "Python 3",
"language": "python",
"name": "python3"
},
"language_info": {
"codemirror_mode": {
"name": "ipython",
"version": 3
},
"file_extension": ".py",
"mimetype": "text/x-python",
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython3",
"version": "3.7.4"
}
},
"nbformat": 4,
"nbformat_minor": 1
}