首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >R:迭代地定义函数内部的函数

R:迭代地定义函数内部的函数
EN

Stack Overflow用户
提问于 2018-11-27 11:31:53
回答 1查看 97关注 0票数 1

给出一个函数列表

代码语言:javascript
复制
functions <- list(f1,f2)

我想迭代地重新定义这个列表中的所有函数,这样我就可以

代码语言:javascript
复制
newFunctions <- list(function(...){f1(...) + 1},function(...){f2(...) + 1})

我试着用

代码语言:javascript
复制
newFunctions <- lapply(functions, function(i){
  return(function(...){
    return(i(...) + 1)
    }
}

但这将i硬编码为函数,而不是迭代器指向的函数。

我找到了R: Defining functions within a loop,解决方案是在定义函数之前对迭代器进行评估。但是,我不能计算i,因为我在迭代函数

有没有办法在R中实现这一点?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-11-27 13:08:26

首先,让我们通过消除显式return调用来修复语法错误:

代码语言:javascript
复制
newFunctions <- lapply(functions, function(x) function(...) x(...) + 1)

使用的一个例子:

代码语言:javascript
复制
functions <- list(sin, cos, tan)
newFunctions <- lapply(functions, function(x) function(...) x(...) + 1)
identical(
  newFunctions[[1]](1), 
  sin(1) + 1
)
#[1] TRUE

代码创建闭包。x是从关联环境中提取的:

代码语言:javascript
复制
newFunctions[[1]]
#function(...) x(...) + 1
#<environment: 0x000000001a812138>
environment(newFunctions[[1]])$x
#function (x)  .Primitive("sin")
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53498713

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档