Paul Gilbert wrote:
A few weeks ago I noticed

 >  z <- matrix(rnorm(20000),10000,2)

 > system.time(for (i in 1:1000) apply(z,2,sum))
[1] 13.44  0.48 14.08  0.00  0.00

 > system.time(for (i in 1:1000) rep(1,10000) %*% z)
[1] 6.46 0.11 6.84 0.00 0.00

which seemed completely contrary to all my childhood teachings. Now

Must have had an interesting childhood if you spent it learning about the speeds of various matrix multiplication techniques.
 > system.time(for (i in 1:1000) crossprod(rep(1,10000), z))
[1] 1.90 0.12 2.24 0.00 0.00

and there is a good chance that a significant portion of that time is taken up by repeating the rep(1, 10000) function call 1000 times.


makes sense because it is suppose to be faster than %*% , but why is apply so slow?

I believe that this is Bert Gunter's cue to comment on the internal (or infernal) nature of the apply functions.


(And should I go back and change apply in my code everywhere or is this likely to reverse again?)

Paul Gilbert

______________________________________________ R-devel@stat.math.ethz.ch mailing list https://stat.ethz.ch/mailman/listinfo/r-devel

Reply via email to