Rééchantillonnage adaptatif

Optimisation des hyperparamètres en R

Dr. Shirin Elsinghorst

Senior Data Scientist

Qu’est-ce que le rééchantillonnage adaptatif ?

Recherche exhaustive (Grid Search)

  • Toutes les combinaisons d’hyperparamètres sont évaluées.

Recherche aléatoire (Random Search)

  • Des sous-ensembles aléatoires de combinaisons sont évalués.

→ L’évaluation de la meilleure combinaison se fait à la fin.

Rééchantillonnage adaptatif

  • Les combinaisons d’hyperparamètres sont rééchantillonnées près de celles performantes.
  • Ainsi, le rééchantillonnage adaptatif est plus rapide et plus efficace.

« Futility Analysis in the Cross-Validation of Machine Learning Models. » Max Kuhn; ARXIV 2014

Optimisation des hyperparamètres en R

Rééchantillonnage adaptatif dans caret

trainControl : method = "adaptive_cv" + search = "random" + adaptive =

  • min : nombre minimal de rééchantillonnages par hyperparamètre

  • alpha : niveau de confiance pour retirer des hyperparamètres

  • method : "gls" pour modèle linéaire ou "BT" pour Bradley–Terry

  • complete : si TRUE, génère l’ensemble complet de rééchantillonnage

fitControl <- trainControl(method = "adaptive_cv",
                             adaptive = list(min = 2, alpha = 0.05, 
                                             method = "gls", complete = TRUE),
                             search = "random")
Optimisation des hyperparamètres en R
  • trainControl() + tuneLength = x
fitControl <- trainControl(method = "adaptive_cv", number = 3, repeats = 3,
                           adaptive = list(min = 2, 
                                           alpha = 0.05, 
                                           method = "gls", 
                                           complete = TRUE),
                             search = "random")

tic() set.seed(42) gbm_model_voters_adaptive <- train(turnout16_2016 ~ ., data = voters_train_data, method = "gbm", trControl = fitControl, verbose = FALSE, tuneLength = 7) toc()
1239.837 sec elapsed
Optimisation des hyperparamètres en R

Rééchantillonnage adaptatif

gbm_model_voters_adaptive
...
Résultats de rééchantillonnage selon les hyperparamètres :
  shrinkage   interaction.depth  n.minobsinnode  n.trees  Accuracy   Kappa       Resamples
  0.07137493   5                  6              4152     0.9564654  0.02856571  9        
  0.08408739   5                 14               674     0.9547185  0.02098853  4        
  0.28552325   8                 15              3209     0.9568141  0.03024238  3        
  0.33663932  10                 13              2595     0.9571130  0.04250979  9        
  0.54251480   3                 24              3683     0.9482171  0.03568586  2        
  0.56406870   7                 25              4685     0.9549898  0.05284333  5        
  0.58695763   8                 24              1431     0.9520286  0.02742592  2        
L’accuracy a été utilisée pour sélectionner le meilleur modèle (valeur la plus élevée).
Les valeurs finales du modèle sont n.trees = 2595,
interaction.depth = 10, shrinkage = 0.3366393 et n.minobsinnode = 13.
Optimisation des hyperparamètres en R

Passons à la pratique !

Optimisation des hyperparamètres en R

Preparing Video For Download...