W tidy model of data science (TM) realizowanego w modelr
, resampled dane są zorganizowane za pomocą list-columns:modelr: Montaż wielu modeli z danymi resampled
library(modelr)
library(tidyverse)
# create the k-folds
df_heights_resampled = heights %>%
crossv_kfold(k = 10, id = "Resample ID")
Możliwe jest map
modelu do każdego z zestawów danych treningowych na liście kolumnie train
i obliczyć wskaźnik wydajności według map
ping na listę-kolumny test
.
Jeśli ma to miejsce w przypadku wielu modeli, należy to powtórzyć dla każdego z modeli.
# create a list of formulas
formulas_heights = formulas(
.response = ~ income,
model1 = ~ height + weight + marital + sex,
model2 = ~ height + weight + marital + sex + education
)
# fit each of the models in the list of formulas
df_heights_resampled = df_heights_resampled %>%
mutate(
model1 = map(train, function(train_data) {
lm(formulas_heights[[1]], data = train_data)
}),
model2 = map(train, function(train_data) {
lm(formulas_heights[[2]], data = train_data)
})
)
# score the models on the test sets
df_heights_resampled = df_heights_resampled %>%
mutate(
rmse1 = map2_dbl(.x = model1, .y = test, .f = rmse),
rmse2 = map2_dbl(.x = model2, .y = test, .f = rmse)
)
co daje:
> df_heights_resampled
# A tibble: 10 × 7
train test `Resample ID` model1 model2 rmse1 rmse2
<list> <list> <chr> <list> <list> <dbl> <dbl>
1 <S3: resample> <S3: resample> 01 <S3: lm> <S3: lm> 58018.35 53903.99
2 <S3: resample> <S3: resample> 02 <S3: lm> <S3: lm> 55117.37 50279.38
3 <S3: resample> <S3: resample> 03 <S3: lm> <S3: lm> 49005.82 44613.93
4 <S3: resample> <S3: resample> 04 <S3: lm> <S3: lm> 55437.07 51068.90
5 <S3: resample> <S3: resample> 05 <S3: lm> <S3: lm> 48845.35 44673.88
6 <S3: resample> <S3: resample> 06 <S3: lm> <S3: lm> 58226.69 54010.50
7 <S3: resample> <S3: resample> 07 <S3: lm> <S3: lm> 56571.93 53322.41
8 <S3: resample> <S3: resample> 08 <S3: lm> <S3: lm> 46084.82 42294.50
9 <S3: resample> <S3: resample> 09 <S3: lm> <S3: lm> 59762.22 54814.55
10 <S3: resample> <S3: resample> 10 <S3: lm> <S3: lm> 45328.48 41882.79
Pytanie:
Można dostać uciążliwe naprawdę szybko, gdy liczba modeli na odkrycie jest duża. modelr
udostępnia funkcję fit_with
, która pozwala na iterację w wielu modelach (co charakteryzuje się wieloma formułami), ale wydaje się, że w powyższym modelu nie jest dostępna kolumna listy, taka jak train
. Zakładam, że jedna z rodziny funkcji *map*
sprawi, że będzie to możliwe (invoke_map
?), Ale nie udało się ustalić, w jaki sposób.
Lubię to rozwiązanie, ale myślę, że nie ma prostsze rozwiązanie, które mam [pisał o na stronie dotyczącej problemów z modelowaniem] (https: // github.com/hadley/modelr/issues/31 # issuecomment-255596156). Pozostała kwestia polega na podzieleniu tej kolumny z listy na jej składniki, co do której jestem pewien, że istnieje (powinno być) rozwiązanie w "purrr". – tchakravarty
Zawsze możesz umieścić odpowiedź na własne pytanie, ale lista list w obrębie data.frame może być dla niektórych niewielka. – Axeman
Nie jest to kompletne rozwiązanie, dopóki nie dowiem się, jak je podzielić z kolumny listy. Skąd to tylko kolumny obiektów S3, jak wszystkie pozostałe. :-) – tchakravarty