Как записать имена нескольких аргументов (…), переданных функции?

#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 будут содержаться переданные аргументы ... с именами, заданными для выражений, используемых для их указания.