bench
Results (June 9, 2009)bench
function was run on an HP
Z800 with
This machine
in the following
results. Thanks go to HP for the donation of this zippy machine to
the Department of Computer Science, Colorado State University!
So, here are some execution times for calculating Z = M * M, followed by Z = Z * M repeated for 49 times, where M is a square matrix. The size, n, of M varies from 5 to 3,125. The implementations in all languages are linked with atlas, except for Matlab. All code is available in this tar file.
Here are the results. Execution times are in milliseconds or seconds for size, n, of matrix from 25 to 3,125. Thanks to Elliot Forney for help with linking with atlas and for writing the C/cublas version.
Matlab | R | Haskell | Python (numpy) | C (atlas) | C/cublas | ||
---|---|---|---|---|---|---|---|
HP Z800 | n = 25 | 1.1 ms | 2.0 ms | 1.3 ms | 1.2 ms, 0.95 with reduce | 1.0 ms | 2.2 ms |
n = 125 | 30.1 ms | 63 ms | 47 ms | 59.8 ms, 16.7 with reduce | 42 ms | 6.9 ms | |
n = 625 | 0.77 s | 1.77 s | 1.40 s | 1.62 s, 0.50 with reduce | 1.37 s | 0.38 s | |
n = 3125 | 76 s | 100 s | 89 s | 167 s, 45.1 with reduce | 91 s | 43 s |
Machines: