3

我一定遗漏了一些明显的东西:

library(Rmpfr)

list.mpfr <- list(mpfr(10, 128), mpfr(20, 128))  # I'd like to turn this into mpfr(c(10, 20), 128)
test <- c(list.mpfr, recursive=TRUE)  # Doesn't work -- should it?
identical(test, list.mpfr)  # False -- test is a list of mpfr1 and no longer a list of mpfr

## I'd expect c.mpfr(..., recursive=TRUE) to do the equivalent of c(list(1:5, 8:10), recursive=TRUE)
getAnywhere(c.mpfr)

我有一个返回长度为 1 的 mpfr 的函数。在上面的示例中,我使用mapply(..., simplify=FALSE)构建类似于 list.mpfr 的内容。我想将长度为 1 的 mpfr 对象组合成一个 mpfr 对象(which.max例如,我可以调用 )。

4

1 回答 1

3

找到了解决方案:

library(Rmpfr)
list.mpfr <- list(mpfr(10, 128), mpfr(20, 128))
desired <- new("mpfr", unlist(list.mpfr))
identical(desired, mpfr(c(10, 20), 128))  # True
于 2013-12-19T22:34:50.263 回答