gpt4 book ai didi

multithreading - 在 R 中使用具有多个线程的 data.table

转载 作者:行者123 更新时间:2023-12-04 06:38:27 26 4
gpt4 key购买 nike

是否可以使用 data.table 来利用多个线程进行计算在R?例如,假设我有以下 data.table :

dtb <- data.table(id=rep(1:10000, 1000), x=1:1e7)
setkey(dtb, id)
f <- function(m) { #some really complicated function }
res <- dtb[,f(x), by=id]

如果 f,有没有办法让 R 多线程?需要一段时间来计算?在 f 的情况下呢?很快,多线程会有所帮助还是大部分时间会被 data.table 占用把事情分成几组?

最佳答案

我不确定这是“多线程”,但也许您打算包含多核解决方案?如果是这样,请查看之前的答案:Performing calculations by subsets of data in R通过搜索“[r] [data.table] parallel”找到

编辑:(在 4 核机器上速度加倍,但我的系统监视器表明这在 mclapply 调用期间仅使用了 2 个内核。)从该线程复制的代码:http://r.789695.n4.nabble.com/Access-to-local-variables-in-quot-j-quot-expressions-tt2315330.html#a2315337

 calc.fake.dt.mclapply <- function (dt) {
mclapply(6*c(1000,1:4,6,8,10),
function(critical.age) {
dt$tmp <- pmax((dt$age < critical.age) * dt$x, 0)
dt[, cumsum.lag(tmp), by = grp]$V1})
}
mk.fake.df <- function (n.groups=10000, n.per.group=70) {
data.frame(grp=rep(1:n.groups, each=n.per.group),
age=rep(0:(n.per.group-1), n.groups),
x=rnorm(n.groups * n.per.group),
## These don't do anything, but only exist to give
## the table a similar size to the real data.
y1=rnorm(n.groups * n.per.group),
y2=rnorm(n.groups * n.per.group),
y3=rnorm(n.groups * n.per.group),
y4=rnorm(n.groups * n.per.group)) }
df <- mk.fake.df
df <- mk.fake.df()
calc.fake.dt.lapply <- function (dt) { # use base lapply for testing
lapply(6*c(1000,1:4,6,8,10),
function(critical.age) {
dt$tmp <- pmax((dt$age < critical.age) * dt$x, 0)
dt[, cumsum.lag(tmp), by = grp]$V1})
}
mk.fake.dt <- function (fake.df) {
fake.dt <- as.data.table(fake.df)
setkey(fake.dt, grp, age)
fake.dt
}
dt <- mk.fake.dt()

require(data.table)
dt <- mk.fake.dt(df)

cumsum.lag <- function (x) {
x.prev <- c(0, x[-length(x)])
cumsum(x.prev)
}
system.time(res.dt.mclapply <- calc.fake.dt.mclapply(dt))
user system elapsed
1.896 4.413 1.210

system.time(res.dt.lapply <- calc.fake.dt.lapply(dt))
user system elapsed
1.391 0.793 2.175

关于multithreading - 在 R 中使用具有多个线程的 data.table,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12013007/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com