Data-Informed Thinking + Doing
Numerical Predictions Using Ridge and Lasso Regression
—using scikit-learn for Python.
Getting Started
Before diving in, the process/pipeline will be the following:
[Flow chart here]
If you are interested in reproducing this work, here are the versions of Python and Python packages used:
import sys
print(sys.version)
## 3.9.1 (v3.9.1:1e5d33e9b9, Dec 7 2020, 12:10:52)
## [Clang 6.0 (clang-600.0.57)]
# !pip install "numpy==1.20.0"
# !pip install "pandas==1.2.2"
# !pip install "matplotlib==3.3.4"
# !pip install "seaborn==0.11.1"
# !pip install "scikit-learn==0.24.1"
import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
import seaborn as sns
from sklearn import datasets
from sklearn import linear_model
sns.set()
plt.style.use("ggplot")
iris = datasets.load_iris()
type(iris)
## <class 'sklearn.utils.Bunch'>
print(iris.keys())
## dict_keys(['data', 'target', 'frame', 'target_names', 'DESCR', 'feature_names', 'filename'])
type(iris.data), type(iris.target)
## (<class 'numpy.ndarray'>, <class 'numpy.ndarray'>)
iris.data.shape
## (150, 4)
iris.target_names
## array(['setosa', 'versicolor', 'virginica'], dtype='<U10')
x = iris.data
y = iris.target
df = pd.DataFrame(x, columns=iris.feature_names)
print(df.head())
## sepal length (cm) sepal width (cm) petal length (cm) petal width (cm)
## 0 5.1 3.5 1.4 0.2
## 1 4.9 3.0 1.4 0.2
## 2 4.7 3.2 1.3 0.2
## 3 4.6 3.1 1.5 0.2
## 4 5.0 3.6 1.4 0.2
_ = pd.plotting.scatter_matrix(df, c = y, figsize = [8, 8], s = 150, marker = "D")
plt.show()
Recent Thoughts