Apprentissage supervisé avec scikit-learn
George Boorman
Core Curriculum Manager, DataCamp
Les performances du modèle dépendent de la façon dont les données sont divisées
Non représentatif de la capacité du modèle à se généraliser à de nouvelles données
Solution : la validation croisée
5 blocs = VC à 5 blocs
10 blocs = VC à 10 blocs
k blocs = VC à k blocs
Plus de blocs = plus de coûts de calcul
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])
Apprentissage supervisé avec scikit-learn