The Computer Language
25.02 Benchmarks Game

Lisp SBCL versus Racket

How the programs are written matters! Always look at the source code.

If the fastest programs are flagged * possible hand-written vector instructions or "unsafe" or naked ffi, does the host language matter? You might be more interested in the less optimised programs — more seconds, less gz source code.

fannkuch-redux      
  elapsed Mean or 95% CI      
source secs cpu secs mem gz make
Lisp SBCL #5 30.88 30.86 58,196 689 2.50
Lisp SBCL #3 36.28 36.26 37,208 833 2.57
Lisp SBCL #4 9.41 36.96 38,060 1531 2.49
Lisp SBCL #2 48.05 48.03 27,795 525 2.47
* Racket #3 30.37 112.68—117.02 129,380 1109
* Racket #2 113.47 114.07—121.01 126,419 916
* Racket 141.45 141.64—144.43 126,550 655
n-body      
  elapsed Mean or 95% CI      
source secs cpu secs mem gz make
Lisp SBCL #2 7.83 7.82 27,808 1408 2.51
Lisp SBCL 9.28 9.27 27,554 1373 2.64
* Racket #2 14.34 14.31—14.49 129,397 1695
Racket 40.86 40.90—41.11 129,057 1503
spectral-norm      
  elapsed Mean or 95% CI      
source secs cpu secs mem gz make
Lisp SBCL #6 5.36 5.35 29,557 512 2.47
Lisp SBCL 5.37 5.35 29,782 639 2.66
Lisp SBCL #9 1.48 5.72 28,799 799 2.56
Lisp SBCL #7 1.47 5.72 29,258 769 2.58
Lisp SBCL #2 1.48 5.72 29,274 920 2.55
Lisp SBCL #3 1.47 5.72 29,598 893 2.50
* Racket #3 3.97 14.87 128,840 639
* Racket #2 15.19 15.14 126,857 539
Racket 29.73 29.71 129,208 452
mandelbrot      
  elapsed Mean or 95% CI      
source secs cpu secs mem gz make
Lisp SBCL 4.53 16.56—16.61 60,678 2478 3.27
Lisp SBCL #4 4.20 16.68 60,654 2453 3.17
Lisp SBCL #3 9.82 26.17—26.21 60,191 900 2.59
* Racket #3 34.91 34.86 127,980 808
* Racket #4 10.68 41.54 190,411 810
Racket 49.62 49.56—49.60 125,587 524
* Racket #2 51.46 51.44—51.50 125,395 592
fasta      
  elapsed Mean or 95% CI      
source secs cpu secs mem gz make
Lisp SBCL #6 4.51 4.49 28,107 1763 2.75
Lisp SBCL #3 5.32 5.33 27,558 1592 2.59
* Racket #3 8.22 8.19—8.23 128,446 1291
Lisp SBCL #2 8.93 8.92 27,910 1628 2.52
Lisp SBCL 9.06 9.08 30,581 1430 2.65
Racket 18.53 18.55—18.67 125,637 1071
k-nucleotide      
  elapsed Mean or 95% CI      
source secs cpu secs mem gz make
Lisp SBCL #4 15.75 15.78—16.30 168,317 2292 2.80
Lisp SBCL #5 15.84 15.85—15.91 169,165 2323 2.88
Lisp SBCL #6 8.79 31.23—32.50 536,506 2485 2.61
Lisp SBCL 10.80 33.59 589,226 2431 2.54
Lisp SBCL #2 44.39 44.57—45.38 528,470 1291 2.57
Lisp SBCL #3 44.68 45.09—45.91 528,470 1297 2.60
Racket #4 61.86 61.88—62.11 991,015 893
Racket 194.59 198.04—200.74 2,679,632 554
reverse-complement      
  elapsed Mean or 95% CI      
source secs cpu secs mem gz make
Lisp SBCL 5.51 5.50 1,538,748 911 2.58
* Racket #2 9.12 9.11—9.20 854,643 1038
Racket 42.51 42.87—43.57 2,151,363 560
Lisp SBCL #2   Timed Out  
binary-trees      [ Contentious. Different approaches. ]
  elapsed Mean or 95% CI      
source secs cpu secs mem gz make
* Racket #3 6.22 6.17—6.21 278,237 480
Lisp SBCL #3 2.83 7.36—7.54 641,151 938 2.54
Racket #2 9.20 9.17—9.24 385,794 422
* Racket #4 4.81 9.54—9.86 471,519 861
Lisp SBCL 9.60 9.62—9.68 665,092 595 2.51
Racket 15.19 15.16—15.20 608,461 482
pidigits      [ Contentious. Different libraries. ]
  elapsed Mean or 95% CI      
source secs cpu secs mem gz make
* Racket #2 1.26 1.21 131,547 1142
Lisp SBCL #4 3.37 3.39 817,934 495 2.62
Lisp SBCL #3 3.38 3.39 817,897 499 2.59
Lisp SBCL #2 6.00 6.01 836,059 655 2.49
Racket 10.49 10.46 129,741 459
regex-redux      [ Contentious. Different libraries. ]
  elapsed Mean or 95% CI      
source secs cpu secs mem gz make
Racket 24.07 24.01—24.07 1,382,437 548
Racket #2 13.95 25.43—25.54 1,646,199 736
Lisp SBCL #4 13.84 29.66—29.75 1,089,716 1977 3.35
Lisp SBCL

SBCL 2.4.8

Racket

Racket v8.15 [cs].