When the length of the end result is not known, doubling the length of the list is also much faster than increasing the size of the list with single items.

f <- function(n, preallocate) {
    v <- if(preallocate) vector("list",n) else list() ;
    for(i in seq_len(n)) {
       v[[i]] <- i
    }
    v
}

g <- function(n) {
    N <- 1000
    v <- vector("list", N)
    for(i in seq_len(n)) {
       if (i > N) {
           N <- 2 * N
           length(v) <- N
       }
       v[[i]] <- i
    }
    v[1:i]
}


> system.time(f(5E4, TRUE))
   user  system elapsed
  0.968   0.000   0.975
> system.time(f(5E4, FALSE))
   user  system elapsed
 52.611   0.136  54.197
> system.time(g(5E4))
   user  system elapsed
  1.388   0.008   1.424


What causes these differences? I can imagine that the time needed for memory allocations play a role: multiple small allocations will be smaller than one large allocation. But that doesn't explain the quadratic growth in time. I would expect that to be linear. When doing v[[i]] <- i the list isn't copied, right?

Jan



On 07/19/2012 06:21 PM, William Dunlap wrote:
Preallocation of lists does speed things up.  The following shows
time quadratic in size when there is no preallocation and linear
growth when there is, for size in the c. 10^4 to 10^6 region:
f <- function(n, preallocate) { v <- if(preallocate)vector("list",n) else list() ; 
for(i in seq_len(n)) v[[i]] <- i ; v }
identical(f(17,pre=TRUE), f(17,pre=FALSE))
[1] TRUE
system.time(f(n=1e4, preallocate=FALSE))
    user  system elapsed
   0.324   0.000   0.326
system.time(f(n=2e4, preallocate=FALSE)) # 2x n, 4x time
    user  system elapsed
   1.316   0.012   1.329
system.time(f(n=4e4, preallocate=FALSE)) # ditto
    user  system elapsed
   5.720   0.028   5.754

system.time(f(n=1e4, preallocate=TRUE))
    user  system elapsed
   0.016   0.000   0.017
system.time(f(n=2e4, preallocate=TRUE)) # 2x n, 2x time
    user  system elapsed
   0.032   0.004   0.036
system.time(f(n=4e4, preallocate=TRUE)) # ditto
    user  system elapsed
   0.068   0.000   0.069

system.time(f(n=4e5, preallocate=TRUE)) # 10x n, 10x time
    user  system elapsed
   0.688   0.000   0.688

Above 10^6 there is some superlinearity
system.time(f(n=4e6, preallocate=TRUE)) # 10x n, 20x time
    user  system elapsed
  11.125   0.052  11.181

Bill Dunlap
Spotfire, TIBCO Software
wdunlap tibco.com


-----Original Message-----
From: r-help-boun...@r-project.org [mailto:r-help-boun...@r-project.org] On
Behalf Of Bert Gunter
Sent: Thursday, July 19, 2012 9:11 AM
To: Hadley Wickham
Cc: r-help@r-project.org
Subject: Re: [R] complexity of operations in R

Hadley et. al:

Indeed. And using a loop is a poor way to do it anyway.

v <- as.list(rep(FALSE,dotot))

is way faster.

-- Bert

On Thu, Jul 19, 2012 at 8:50 AM, Hadley Wickham <had...@rice.edu> wrote:
On Thu, Jul 19, 2012 at 8:02 AM, Jan van der Laan <rh...@eoos.dds.nl> wrote:
Johan,

Your 'list' and 'array doubling' code can be written much more efficient.

The following function is faster than your g and easier to read:

g2 <- function(dotot) {
   v <- list()
   for (i in seq_len(dotot)) {
     v[[i]] <- FALSE
   }
}

Except that you don't need to pre-allocate lists...

Hadley

--
Assistant Professor / Dobelman Family Junior Chair
Department of Statistics / Rice University
http://had.co.nz/

______________________________________________
R-help@r-project.org mailing list
https://stat.ethz.ch/mailman/listinfo/r-help
PLEASE do read the posting guide http://www.R-project.org/posting-guide.html
and provide commented, minimal, self-contained, reproducible code.



--

Bert Gunter
Genentech Nonclinical Biostatistics

Internal Contact Info:
Phone: 467-7374
Website:
http://pharmadevelopment.roche.com/index/pdb/pdb-functional-groups/pdb-
biostatistics/pdb-ncb-home.htm

______________________________________________
R-help@r-project.org mailing list
https://stat.ethz.ch/mailman/listinfo/r-help
PLEASE do read the posting guide http://www.R-project.org/posting-guide.html
and provide commented, minimal, self-contained, reproducible code.

______________________________________________
R-help@r-project.org mailing list
https://stat.ethz.ch/mailman/listinfo/r-help
PLEASE do read the posting guide http://www.R-project.org/posting-guide.html
and provide commented, minimal, self-contained, reproducible code.


______________________________________________
R-help@r-project.org mailing list
https://stat.ethz.ch/mailman/listinfo/r-help
PLEASE do read the posting guide http://www.R-project.org/posting-guide.html
and provide commented, minimal, self-contained, reproducible code.

Reply via email to