#r #tidyverse #tidymodels
#r #tidyverse #tidymodels
Вопрос:
У меня есть пара моделей, которые передаются функцией, количество моделей является переменным. Через (…) я могу передать все модели следующим образом:
library(tidymodels)
library(dplyr)
model_1 = decision_tree(mode = "regression") %>% set_engine("rpart") %>% fit(Sepal.Length ~ Petal.Length, data = iris)
model_2 = decision_tree(mode = "regression") %>% set_engine("rpart") %>% fit(Sepal.Length ~ Petal.Length Petal.Width, data = iris)
F.function = function(...){
a = list(...)
a
}
F.function(model_1,model_2)
#> [[1]]
#> parsnip model object
#>
#> Fit time: 15ms
#> n= 150
#>
#> node), split, n, deviance, yval
#> * denotes terminal node
#>
#> 1) root 150 102.1683000 5.843333
#> 2) Petal.Length< 4.25 73 13.1391800 5.179452
#> 4) Petal.Length< 3.4 53 6.1083020 5.005660 *
#> 5) Petal.Length>=3.4 20 1.1880000 5.640000 *
#> 3) Petal.Length>=4.25 77 26.3527300 6.472727
#> 6) Petal.Length< 6.05 68 13.4923500 6.326471
#> 12) Petal.Length< 5.15 43 8.2576740 6.165116 *
#> 13) Petal.Length>=5.15 25 2.1896000 6.604000 *
#> 7) Petal.Length>=6.05 9 0.4155556 7.577778 *
#>
#> [[2]]
#> parsnip model object
#>
#> Fit time: 5ms
#> n= 150
#>
#> node), split, n, deviance, yval
#> * denotes terminal node
#>
#> 1) root 150 102.1683000 5.843333
#> 2) Petal.Length< 4.25 73 13.1391800 5.179452
#> 4) Petal.Length< 3.4 53 6.1083020 5.005660 *
#> 5) Petal.Length>=3.4 20 1.1880000 5.640000 *
#> 3) Petal.Length>=4.25 77 26.3527300 6.472727
#> 6) Petal.Length< 6.05 68 13.4923500 6.326471
#> 12) Petal.Length< 5.15 43 8.2576740 6.165116 *
#> 13) Petal.Length>=5.15 25 2.1896000 6.604000 *
#> 7) Petal.Length>=6.05 9 0.4155556 7.577778 *
Но когда модели сохраняются в списке, они не сохраняют имя, есть ли какой-либо способ получить следующий вывод, сохраняющий имена с использованием (…) ?
list(model_1 = model_1,
model_2 = model_2)
#> $model_1
#> parsnip model object
#>
#> Fit time: 15ms
#> n= 150
#>
#> node), split, n, deviance, yval
#> * denotes terminal node
#>
#> 1) root 150 102.1683000 5.843333
#> 2) Petal.Length< 4.25 73 13.1391800 5.179452
#> 4) Petal.Length< 3.4 53 6.1083020 5.005660 *
#> 5) Petal.Length>=3.4 20 1.1880000 5.640000 *
#> 3) Petal.Length>=4.25 77 26.3527300 6.472727
#> 6) Petal.Length< 6.05 68 13.4923500 6.326471
#> 12) Petal.Length< 5.15 43 8.2576740 6.165116 *
#> 13) Petal.Length>=5.15 25 2.1896000 6.604000 *
#> 7) Petal.Length>=6.05 9 0.4155556 7.577778 *
#>
#> $model_2
#> parsnip model object
#>
#> Fit time: 5ms
#> n= 150
#>
#> node), split, n, deviance, yval
#> * denotes terminal node
#>
#> 1) root 150 102.1683000 5.843333
#> 2) Petal.Length< 4.25 73 13.1391800 5.179452
#> 4) Petal.Length< 3.4 53 6.1083020 5.005660 *
#> 5) Petal.Length>=3.4 20 1.1880000 5.640000 *
#> 3) Petal.Length>=4.25 77 26.3527300 6.472727
#> 6) Petal.Length< 6.05 68 13.4923500 6.326471
#> 12) Petal.Length< 5.15 43 8.2576740 6.165116 *
#> 13) Petal.Length>=5.15 25 2.1896000 6.604000 *
#> 7) Petal.Length>=6.05 9 0.4155556 7.577778 *
Создано 2021-01-13 пакетом reprex (версия 0.3.0)
Ответ №1:
Вы не использовали никаких имен для этих аргументов. Если бы вы это сделали, это было бы частью результата. Например, используйте
F.function(m1 = model_1,m2 = model_2)
Если вы хотите сгенерировать имена из переданных вами выражений, вы могли бы сделать это:
exprs <- substitute(list(...))
vals <- list(...)
names(vals) <- vapply(as.list(exprs), deparse, "")[-1]
На этом этапе vals
будут содержаться переданные аргументы ...
с именами, заданными для выражений, используемых для их указания.