r - "vectorize"具有不同参数长度的函数的最快方法

标签 r function performance vectorization

取下面的简单函数:

fun <- function(a, b, c, d, e) {
   
   stopifnot("Input you provide must be equal length." = length(a) == length(b) && length(b) == length(c) && length(c) == length(d) && length(d) == length(e))

   result <- (a + b / c + d) / sqrt(e)
   
   result2 <- a/result

   return(data.frame(result = result, result2 = result2, a = a, b = b, c = c, d = d, e = e))
}
现在,如果我想映射所有输入值组合的查找表,我可以执行以下操作,例如,使用 purrr泛函:
library(purrr)

df <- expand.grid(a = 1:1000, b = c(1, 2, 3, 4, 5), c = 7, d = 3, e = 5)

out <- pmap_df(d, fun)
然而,即使对于一个较大和较小向量的相对简单的情况(在我的应用案例中,这将是最常见的情况),这也很慢。
Unit: seconds                                                                             
      min       lq     mean   median       uq      max neval
 2.235245 2.235245 2.235245 2.235245 2.235245 2.235245     1
如何加快速度,尤其是对于上面勾画的简单案例?当然,如df变得越来越大,事情会变慢。

最佳答案

我不能说我的解决方案是最快的,但它确实更快。你可以试试下面的代码

do.call(fun, df)
和基准测试
df <- expand.grid(a = 1:1000, b = c(1, 2, 3, 4, 5), c = 7, d = 3, e = 5)


f_Rob <- function() pmap_df(df, function(a, b, c, d, e) fun(a = a, b = b, c = c, d = d, e = e))
f_TIC <- function() do.call(fun, df)

microbenchmark(
  f_Rob(),
  f_TIC(),
  unit = "relative",
  check = "equivalent",
  times = 10
)
你会看到
Unit: relative
    expr      min       lq     mean   median       uq      max neval
 f_Rob() 1074.886 1049.034 441.6319 854.2739 620.4029 92.29739    10
 f_TIC()    1.000    1.000   1.0000   1.0000   1.0000  1.00000    10

关于r - "vectorize"具有不同参数长度的函数的最快方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68712116/

相关文章:

MySQL SQL 性能需要一些改进

用另一列R替换一列中的值

r - 在 R 中使用主键创建 SQLite 表

c++ - 函数原型(prototype)作用域示例

c++ - 使编译器/优化器能够制作更快的程序的编码实践

javascript - 当我们不需要它们的所有功能时,为什么要下载完整的 JavaScript 框架?我们有什么建议? (JavaScript)

R从系统命令的标准输出读取数据到数据帧

r - Shiny DT : format date column in excel through Buttons extensions

javascript - 如何更改函数内部的值?

c - 在 C 中序列化函数