Reamostragem adaptativa

Ajuste de hiperparâmetros em R

Dr. Shirin Elsinghorst

Senior Data Scientist

O que é reamostragem adaptativa?

Grid Search

  • Todas as combinações de hiperparâmetros são avaliadas.

Random Search

  • Subconjuntos aleatórios de combinações são avaliados.

→ A melhor combinação é avaliada no fim.

Reamostragem adaptativa

  • Reamostra combinações de hiperparâmetros perto das que foram bem.
  • Assim, é mais rápida e eficiente!

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

Ajuste de hiperparâmetros em R

Reamostragem adaptativa no caret

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

  • min: número mínimo de reamostragens por hiperparâmetro

  • alpha: nível de confiança para remover hiperparâmetros

  • method: "gls" para modelo linear ou "BT" para Bradley-Terry

  • complete: se TRUE, gera o conjunto completo de reamostragem

fitControl <- trainControl(method = "adaptive_cv",
                             adaptive = list(min = 2, alpha = 0.05, 
                                             method = "gls", complete = TRUE),
                             search = "random")
Ajuste de hiperparâmetros em 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
Ajuste de hiperparâmetros em R

Reamostragem adaptativa

gbm_model_voters_adaptive
...
Resultados de reamostragem nos parâmetros de ajuste:
  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        
Accuracy foi usada para selecionar o melhor modelo pelo maior valor.
Os valores finais do modelo foram n.trees = 2595,
interaction.depth = 10, shrinkage = 0.3366393 e n.minobsinnode = 13.
Ajuste de hiperparâmetros em R

Vamos praticar!

Ajuste de hiperparâmetros em R

Preparing Video For Download...