2

假设我有一个外部函数,它有一个数字参数和一个函数本身(内部函数)的参数。如何将外部函数的数字参数的值作为参数传递给内部函数?考虑这个玩具示例:

innerfun <- function(M){
 1:M
}

outerfun <- function(x, fun){
 x * fun
}

outerfun(x = 3, fun = innerfun(M = 3)) ## works
outerfun(x = 3, fun = innerfun(M = x)) ## error because innerfun can't find 'x'
outerfun(x = 3, fun = innerfun(M = get("x"))) ## doesn't work either...

所以我想做的是在评估outerfun的参数时调用innerfun,在调用innerfun时使用这些outerfun-arguments。有什么想法或建议吗?

4

2 回答 2

5

我会做这样的事情:

outerfun <- function(x, fun,...){
  x * fun(x,...)
}
innerfun <- function(M){
  seq_len(M) ## safer than 1:M
}
outerfun(x=3, innerfun)
[1] 3 6 9

请注意,如果内部函数有多个参数,它仍然有效:

innerfun2 <- function(M,Z){
  seq(M+Z)
}
outerfun(x=3, innerfun2,Z=3)
[1]  3  6  9 12 15 18
于 2013-09-29T07:27:54.267 回答
0

添加一个“全局”变量:

param = 3;
outerfun(x = param, fun = innerfun(M = param))
于 2013-09-29T07:44:19.117 回答