使用big64包时,将一个向量NAs与另一个整数向量相加会产生不准确的结果。根据NA向量是先求和还是最后求和,结果将分别是0正确答案的一个或两倍。
请注意,将NA向量从 integer64 转换为将消除该问题。
然而,当用其他小值代替 y 进行试验时,结果非常奇怪。例如:
40 + 35 = 75    but
35 + 40 = 80
关于发生了什么的任何想法?
例子:
  library(bit64)
  x <- as.integer64(c(20, 20))
  y <- as.integer64(c(NA, NA))
  sum(y, x, na.rm=TRUE)
  # integer64
  # [1] 80   # <~~~ Twice the correct value
  sum(x, y, na.rm=TRUE)
  # integer64
  # [1] 0   # <~~~~ Incorrect 0.  Should be 40. 
  ## Removing the NAs does not help. 
  y <- y[!is.na(y)]
  ## A vector of 0's gives the same issue
  y <- as.integer64(c(0, 0))
  ## Same results
  sum(y, x, na.rm=TRUE)
  # integer64
  # [1] 80
  sum(x, y, na.rm=TRUE)
  # integer64
  # [1] 0
  ## Converting to numeric does away with the issue (but is not a viable workaround, for obvious reasons)
  y <- as.numeric(y)
  sum(y, x, na.rm=TRUE)
  # [1] 1.97626e-322
  sum.integer64(y, x, na.rm=TRUE)
  # integer64
  # [1] 40
  sum(x, y, na.rm=TRUE)
  # integer64
  # [1] 40
给y一个值,结果也很格格不入
  y <- as.integer64(c(35, NA, NA))
  sum.integer64(x, if (!all(is.na(y))) removeNA(y), na.rm=TRUE)
  sum.integer64(x, y[[1]], na.rm=TRUE)
  sum.integer64(y[[1]], x, na.rm=TRUE)
  ## No NA's present
  sum.integer64(as.integer64(35), x)
  # integer64
  # [1] 80
  sum.integer64(x, as.integer64(35))
  # integer64
  # [1] 70