Aprendizado Supervisionado com o scikit-learn
George Boorman
Core Curriculum Manager, DataCamp
$y = ax + b$
A regressão linear simples usa uma única variável independente
$y$ = variável dependente
$x$ = apenas uma variável independente
$a$, $b$ = parâmetros/coeficientes do modelo – inclinação, intercepto
Como escolher $a$ e $b$?
Definir uma função de erro para uma determinada linha
Escolher a linha que minimiza a função de erro
Função de erro = função de perda = função de custo
$RSS = $ $\displaystyle\sum_{i=1}^{n}(y_i-\hat{y_i})^2$
Método dos Mínimos Quadrados (MMQ): minimiza a SQR (RSS, em inglês)
$$ y = a_{1}x_{1} + a_{2}x_{2} + b$$
$$ y = a_{1}x_{1} + a_{2}x_{2} + a_{3}x_{3} +... + a_{n}x_{n}+ b$$
from sklearn.model_selection import train_test_split from sklearn.linear_model import LinearRegression
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.3, random_state=42)
reg_all = LinearRegression()
reg_all.fit(X_train, y_train)
y_pred = reg_all.predict(X_test)
$R^2$: quantifica a variância nos valores da variável dependente explicada pelas variáveis independentes
$R^2$ alto:
reg_all.score(X_test, y_test)
0.356302876407827
$MSE = $ $\displaystyle\frac{1}{n}\sum_{i=1}^{n}(y_i-\hat{y_i})^2$
$RMSE = $ $\sqrt{MSE}$
from sklearn.metrics import root_mean_squared_error
root_mean_squared_error(y_test, y_pred)
24.028109426907236
Aprendizado Supervisionado com o scikit-learn