Evite la duplicación de argumentos al pasar por (...)
Considere la función
f <- function(x, X) mean(c(x,X))
¿Cómo puedo automáticamente (mediante la manipulación def()
) cambiar la firma def()
de modo que se pueda usar conlapply()
, es decir, sin devolver el siguiente error obvio?
lapply(X=list(1), FUN=f, X=1)
Error in lapply(X = list(1), FUN = f, X = 1) :
formal argument "X" matched by multiple actual arguments
El enfoque que utilicé hasta ahora es eliminar todos los argumentos def()
, asignarlos a un entorno y evaluarf()
en ese entorno.
integrateArgs <- function (f, args)
{
form <- formals(f)
if (!is.null(form))
for (i in seq_along(form)) assign(names(form)[i], form[[i]])
if (!is.null(args))
for (i in seq_along(args)) assign(names(args)[i], args[[i]])
ff <- function() {
}
parent.env(environment(ff)) <- parent.env(environment(f))
body(ff) <- body(f)
if (any(names(form) == "..."))
formals(ff) <- form[names(form) == "..."]
ff
}
fnew <- integrateArgs(f, list(x=1, X=4))
lapply(list(fnew), function(x) x())
[[1]]
[1] 2.5
Sin embargo, ese enfoque conduce al siguiente error sif()
es una función de otro paquete R que llama a código compilado.
fnew2 <- integrateArgs(dnorm, list(x=1, mean=4))
lapply(list(fnew2), function(x) x())
Error in x() (from #1) : object 'C_dnorm' not found
¿Hay mejores soluciones?