gpt4 book ai didi

r - parLapply 在 R6 类别内

转载 作者:行者123 更新时间:2023-12-02 15:24:00 25 4
gpt4 key购买 nike

我希望在 R6 对象中的窗口上使用 parLapply() ,并注意到(至少在某些情况下)我不需要导出R6 功能或数据到节点。

这是一个示例,我可以在 parLapply() 中访问私有(private)方法:

require(R6);require(parallel)
square <-
R6Class("square",
public = list(
numbers = NA,
squares = NA,
initialize = function(numbers,integer) {
self$numbers <- numbers
squares <- private$square.numbers()
}
),
private = list(
square = function(x) {
return(x^2)
},
square.numbers = function() {
cl <- makeCluster(detectCores())
self$squares <- parLapply(cl,
self$numbers,
function (x) private$square(x)
)
stopCluster(cl)
}
))
##Test
test <- square$new(list(1,2,3))
print(test$squares)
# [[1]]
# [1] 1
#
# [[2]]
# [1] 4
#
# [[3]]
# [1] 9

还有第二个例子,我也可以访问公共(public)成员:

square2 <-
R6Class("square2",
public = list(
numbers = NA,
squares = NA,
integer = NA,
initialize = function(numbers,integer) {
self$numbers <- numbers
self$integer <- integer
squares <- private$square.numbers()
}
),
private = list(
square = function(x) {
return(x^2)
},
square.numbers = function() {
cl <- makeCluster(detectCores())
self$squares <- parLapply(cl,
self$numbers,
function (x) private$square(x)+self$integer
)
stopCluster(cl)
}
))
##Test
test2 <- square2$new(list(1,2,3),2)
print(test2$squares)
#[[1]]
#[1] 3
#
#[[2]]
#[1] 6
#
#[[3]]
#[1] 11

我的问题有两个:(1)R6 怎样使这成为可能,这样我就不需要导出数据对象和函数了? (2) 我可以依赖这种行为还是这是这些特定示例的产物?

更新:

在实例化对象后,此行为似乎也可以使用公共(public)方法和成员来工作:

square3 <- R6Class(
classname = "square3",
public = list(
numbers = NA,
squares = NA,
integer = NA,
square = function(x) {
return(x^2)
},
square.numbers = function() {
cl <- makeCluster(detectCores())
self$squares <- parLapply(cl,
self$numbers,
function (x) self$square(x)+self$integer
)
stopCluster(cl)
},
initialize = function(numbers,integer) {
self$numbers <- numbers
self$integer <- integer
}
)
)
test3.obj <- square3$new(list(1,2,3),2)
test3.obj$square.numbers()
test3.obj$squares

# [[1]]
# [1] 3
#
# [[2]]
# [1] 6
#
# [[3]]
# [1] 11

最佳答案

使用 R6 类,每次实例化一个对象时,该对象都会获得每个函数/方法的副本,并具有修改后的环境。这些函数被分配的环境为 self指向对象的公共(public)环境(这是对象的公共(public)面孔),并且 private指向对象的私有(private)环境。

这与 S3 方法不同,S3 方法不会为对象的每个实例化进行复制。

总结:使用 R6,一切都在对象中独立存在;对于 S3,对象不包含方法。

我不太熟悉使用 parLapply ,但我认为依赖 parLapply 那样的东西是安全的.

关于r - parLapply 在 R6 类别内,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34784932/

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