[datatable-help] segfault with "large" number of rows
    "Günter J. Hitsch" 
    guenter.hitsch at mac.com
       
    Wed Jan 22 21:52:12 CET 2014
    
    
  
I’ve been using data.table for several months.  It’s a great package—thank you for developing it!
Here’s my question:  I’ve run into a problem when I use “large” data tables with many millions of rows.  In particular, for such large data tables I get segmentation faults when I create columns by groups.  Example:
N = 2500			# No. of groups
T = 100000		# No. of observations per group
DT = data.table(group = rep(1:N, each = T), x = 1)
setkey(DT, group)
DT[, sum_x := sum(x), by = group]
print(head(DT))
This runs fine.  But when I increase the number of groups, say from 2500 to 3000, I get a segfault:
N = 3000			# No. of groups
T = 100000		# No. of observations per group
...
 *** caught segfault ***
address 0x159069140, cause 'memory not mapped'
Traceback:
 1: `[.data.table`(DT, , `:=`(sum_x, sum(x)), by = group)
 2: DT[, `:=`(sum_x, sum(x)), by = group]
 3: eval(expr, envir, enclos)
 4: eval(ei, envir)
 5: withVisible(eval(ei, envir))
I can reproduce this problem on:
(1) OS X 10.9, R 3.0.2, data.table 1.8.10
(2) Ubuntu 13.10, R 3.0.1, data.table 1.8.10
And of course the amount of RAM in my machines is not the issue.
Thanks in advance for your help with this!
Günter
    
    
More information about the datatable-help
mailing list