Aprendizado Supervisionado com o scikit-learn
George Boorman
Core Curriculum Manager, DataCamp
O desempenho do modelo depende da maneira como dividimos os dados
Não representa a capacidade do modelo de generalizar para dados não vistos
Solução: validação cruzada
5 grupos = validação cruzada com 5 grupos
10 grupos = validação cruzada com 10 grupos
k grupos = validação cruzada com k grupos (k-fold CV)
Mais grupos = mais caro do ponto de vista computacional
from sklearn.model_selection import cross_val_score, KFold
kf = KFold(n_splits=6, shuffle=True, random_state=42)
reg = LinearRegression()
cv_results = cross_val_score(reg, X, y, cv=kf)
print(cv_results)
[0.70262578, 0.7659624, 0.75188205, 0.76914482, 0.72551151, 0.73608277]
print(np.mean(cv_results), np.std(cv_results))
0.7418682216666667 0.023330243960652888
print(np.quantile(cv_results, [0.025, 0.975]))
array([0.7054865, 0.76874702])
Aprendizado Supervisionado com o scikit-learn