OUT-OF-DATE! Read http://shootout.alioth.debian.org/ |
Do the Java 6 -server programs use optimized assembly code libraries? Are they small simple programs or very optimized programs? Do the Java 6 -server programs use a fraction of the time used by other programs or do they use several times more?
| Java 6 -server used what fraction? used how many times more? | ||||
|---|---|---|---|---|
| Programs | Time | Memory | Code | Reduced N |
| ↓ spectral-norm | 1/170 | 4× | 2× | |
| ↓ recursive | 1/133 | ± | ± | |
| ↓ mandelbrot | 1/124 | 6× | 2× | |
| ↓ n-body | 1/115 | 6× | ± | |
| ↓ fannkuch | 1/77 | 6× | 2× | |
| ↓ fasta | 1/44 | 5× | ± | |
| ↓ binary-trees | 1/35 | 1/2 | ± | |
| ↓ nsieve-bits | 1/20 | 3× | 2× | |
| ↓ nsieve | 1/11 | 1/6 | ± | |
| ↓ sum-file | 1/4 | 7× | 3× | |
| ↓ k-nucleotide | 1/2 | 2× | 3× | |
| ↓ partial-sums | 1/2 | 6× | ± | |
| ↓ pidigits | 1/2 | 4× | 2× | |
| ↓ reverse-complement | 1/2 | 2× | 2× | |
| ↓ regex-dna | 1/2 | 4× | 2× | |
± look at the measurements and then look at the programs.
| Program & Logs | CPU secs | Elapsed secs | Memory KB | Code B | ~ CPU Load |
|---|---|---|---|---|---|
| spectral-norm | |||||
| Java 6 -server | 24.01 | 10,008 | 514 | ||
| Perl | 4,089.08 | 2,468 | 334 | ||
| recursive | |||||
| Java 6 -server | 6.76 | 12,044 | 427 | ||
| Perl | 898.78 | 10,836 | 380 | ||
| mandelbrot | |||||
| Java 6 -server | 3.24 | 11,092 | 623 | ||
| Perl | 403.20 | 1,724 | 311 | ||
| n-body | |||||
| Java 6 -server | 14.75 | 11,524 | 1424 | ||
| Perl | 1,697.59 | 1,936 | 1140 | ||
| fannkuch | |||||
| Java 6 -server | 11.05 | 8,884 | 555 | ||
| Perl | 855.72 | 1,492 | 348 | ||
| fasta | |||||
| Java 6 -server | 21.46 | 9,184 | 1240 | ||
| Perl | 950.04 | 1,872 | 934 | ||
| binary-trees | |||||
| Java 6 -server | 6.89 | 26,808 | 603 | ||
| Perl | 239.36 | 47,936 | 541 | ||
| nsieve-bits | |||||
| Java 6 -server | 5.04 | 13,364 | 523 | ||
| Perl | 100.18 | 4,004 | 253 | ||
| nsieve | |||||
| Java 6 -server | 2.25 | 20,592 | 296 | ||
| Perl | 25.45 | 121,904 | 290 | ||
| sum-file | |||||
| Java 6 -server | 4.10 | 9,972 | 226 | ||
| Perl | 18.17 | 1,468 | 84 | ||
| k-nucleotide | |||||
| Java 6 -server | 15.89 | 70,964 | 1052 | ||
| Perl | 32.07 | 42,816 | 359 | ||
| partial-sums | |||||
| Java 6 -server | 9.15 | 8,488 | 474 | ||
| Perl | 17.41 | 1,476 | 389 | ||
| pidigits | |||||
| Java 6 -server | 1.92 | 8,992 | 938 | ||
| Perl | 3.61 | 2,532 | 385 | ||
| reverse-complement | |||||
| Java 6 -server | 1.30 | 58,932 | 592 | ||
| Perl | 1.99 | 38,360 | 298 | ||
| regex-dna | |||||
| Java 6 -server | 7.81 | 75,892 | 921 | ||
| Perl | 11.81 | 21,408 | 431 | ||
| chameneos-redux | |||||
| Java 6 -server | 17.51 | 12,092 | 1429 | ||
java version "1.6.0_07"
Java(TM) SE Runtime Environment (build 1.6.0_07-b06)
Java HotSpot(TM) Server VM (build 10.0-b23, mixed mode, sharing)
Home Page: http://java.sun.com/j2se/
Download: http://java.sun.com/j2se/downloads/
"Remember how HotSpot works. It starts by running your program with an interpreter. When it discovers that some method is "hot" -- that is, executed a lot, either because it is called a lot or because it contains loops that loop a lot -- it sends that method off to be compiled. After that one of two things will happen, either the next time the method is called the compiled version will be invoked (instead of the interpreted version) or the currently long running loop will be replaced, while still running, with the compiled method. The latter is known as "on stack replacement" and exists in the 1.3/1.4 HotSpot based systems."