Evaluate an R expression while collecting journals from completed futures
Source:R/100.capture_journals.R
capture_journals.RdEvaluate an R expression while collecting journals from completed futures
Usage
capture_journals(expr, substitute = TRUE, envir = parent.frame())Details
This function evaluates an R expression and capture the journals signaled by futures as they are completed. A future journal comprise a log of events appearing during the life-span of a future, e.g. the timestamps when the future was created, launched, queried, resolved, and its results are collected.
Examples
slow_fcn <- function(x) {
Sys.sleep(x / 10)
sqrt(x)
}
plan(multisession, workers = 2)
js <- capture_journals({
fs <- lapply(3:1, FUN = function(x) future(slow_fcn(x)))
value(fs)
})
## Summarize all journals
js_all <- Reduce(rbind, js)
print(summary(js_all), digits = 2L)
#> Number of futures: 3
#> summary evaluate evaluate_ratio overhead overhead_ratio duration
#> 1 min 0.11 secs 0.19 0.017 secs 0.03 0.56 secs
#> 2 mean 0.29 secs 0.45 0.199 secs 0.31 0.64 secs
#> 3 median 0.33 secs 0.50 0.026 secs 0.04 0.65 secs
#> 4 max 0.43 secs 0.60 0.556 secs 0.78 0.72 secs
#> 5 total 0.86 secs 0.45 0.598 secs 0.31 1.92 secs
#> walltime
#> 1 0.56 secs
#> 2 0.64 secs
#> 3 0.65 secs
#> 4 0.72 secs
#> 5 1.92 secs
## Shut down parallel workers
plan(sequential)