首页 > 解决方案 > R: bench::mark 不返回最大值和平均值

问题描述

考虑以下示例

res <- bench::mark(rnorm(1e5))
names(res)
#>  [1] "expression" "min"        "median"     "itr/sec"    "mem_alloc" 
#>  [6] "gc/sec"     "n_itr"      "n_gc"       "total_time" "result"    
#> [11] "memory"     "time"       "gc"

我有点困惑,不包括平均值和最大运行时间,这与帮助页面相矛盾。工作台版本是 1.0.4 和 R 3.63。

有谁知道这里的问题是什么?

标签: rbenchmarking

解决方案


运行通常很有用

str(res)

看看函数的输出是什么。在这种情况下,对象的成员之一,接近尾声,是

# $ time      :List of 1
#  ..$ : 'bench_time' num  12.3ms 16.1ms 17.9ms 12.3ms 13.4ms ...

这意味着这res$time是一个只有一个成员的列表。
所以结果被保存下来,res$time[[1]]并且可以从中计算出平均值和最大值。

例如,median(res$time[[1]])与打印结果进行比较。它们是相同的值。

median(res$time[[1]])
#[1] 12.3ms

平均值和最大值将是

mean(res$time[[1]])
#[1] 12.5ms
max(res$time[[1]])
#[1] 17.9ms

推荐阅读