9

我有一个完全由integer64我想转换为矩阵的列组成的数据框。

library(bit64)
(dfr <- data.frame(x = as.integer64(10^(9:18))))
##                      x
## 1           1000000000
## 2          10000000000
## 3         100000000000
## 4        1000000000000
## 5       10000000000000
## 6      100000000000000
## 7     1000000000000000
## 8    10000000000000000
## 9   100000000000000000
## 10 1000000000000000000

不幸的是,as.matrix没有给出正确的答案。

(m <- as.matrix(dfr))
##                   x
##  [1,] 4.940656e-315
##  [2,] 4.940656e-314
##  [3,] 4.940656e-313
##  [4,] 4.940656e-312
##  [5,] 4.940656e-311
##  [6,] 4.940656e-310
##  [7,] 4.940656e-309
##  [8,] 5.431165e-308
##  [9,] 5.620396e-302
## [10,] 7.832953e-242

问题似乎是integer64值被存储为具有“integer64”类属性的数值(加上一些使它们正确打印和执行算术的魔法),该属性被as.matrix.

我不能这样做class(m) <- "integer64",因为这会改变矩阵对象的类而不是它的内容。

同样,mode(m) <- "integer64"给出错误的答案typeof(m) <- "integer64"storage.mode(m) <- "integer64"抛出错误。

当然,我可以通过将列转换为双 ( dfr$x <- as.double(dfr$x)) 来规避这个问题,但感觉应该有一种方法可以正确地做到这一点。

如何获得integer64值矩阵?

4

1 回答 1

4

对于原始向量,dim直接分配属性似乎有效:

> z <- as.integer64(1:10)
> z
integer64
 [1] 1  2  3  4  5  6  7  8  9  10
> dim(z) <- c(10, 1)
> z
integer64
      [,1]
 [1,] 1   
 [2,] 2   
 [3,] 3   
 [4,] 4   
 [5,] 5   
 [6,] 6   
 [7,] 7   
 [8,] 8   
 [9,] 9   
[10,] 10  

对于数据框,cbinding 列也可以:

> df <- data.frame(x=as.integer64(1:5), y=as.integer64(6:10))
> df
  x  y
1 1  6
2 2  7
3 3  8
4 4  9
5 5 10
> cbind(df$x, df$y)
integer64
     [,1] [,2]
[1,] 1    6   
[2,] 2    7   
[3,] 3    8   
[4,] 4    9   
[5,] 5    10  

因此,对于任意数量的列,do.call要走的路是:

> do.call(cbind, df)
integer64
     x y 
[1,] 1 6 
[2,] 2 7 
[3,] 3 8 
[4,] 4 9 
[5,] 5 10
于 2015-02-01T15:29:57.263 回答