fib

Recursive Fibonacci Benchmark - Multiple languages.

fib

Recursive & Iterative Fibonacci Benchmark - Multiple languages.

Performance compare between languages using recursion & iteration.

Here is the Ruby version:

def fib_recursive(n)
  	return n if n <= 1
  	fib_recursive(n - 1) + fib_recursive(n - 2)
end

def fib_iterative(n)
	a = 0
	b = 1
	(0...n).each {
		c = a + b
		a, b = b, c
	}
	a
end

start_time = Time.now
puts fib_recursive(42)
elapsed_time = Time.now - start_time
printf("Seconds Recursive took: %5.3f s.\n", elapsed_time)

start_time = Time.now
puts fib_iterative(42)
elapsed_time = Time.now - start_time
printf("Seconds Iterative took: %5.3f s.\n", elapsed_time)

#Results on a Late 2013 15" Macbook Pro (2.3 GHz Quad-Core i7 - 16GB RAM - Catalina):

42nd number: 267914296.

Showing only recursive as iterative versions are way faster. (So much faster that had to double check compilers were not computing it at compile time).

Rust is significantly faster. Crystal delivers impresive performance compared to C, Go, Swift and Zig. And a pleasure to use. V is fun to code with - needs to mature a bit more.

Interpreted Python and Ruby improve performance significantly using jit. Rust Python Module and Rust Ruby Gem deliver same speed as native Rust! (see separate folders for rust python module and ruby gem projects)

Language secs.millis method command
Ruby 3.0 26.840 recursive ruby fib.rb
Ruby 3.0 8.822 recursive + jit ruby --jit-wait fib.rb
Ruby + Rust 0.780 Ruby calling Rust ruby fib_rust_gem.rb
Crystal 0.36.1 1.370 faster using UInt64 crystal build --release -Dpreview_mt fib.cr
Rust 1.51.0 0.779 recursive rustc -O fib.rs
Go 1.16.1 1.745 faster using uint64 go build fib.go
Python 3.9.2 113.887 recursive python fib.py
Python 3.9.2 2.703 recursive + numba jit python fibn.py (includes compilation time!)
Python + Rust 0.849 calling Rust fast u64 python fib_rust_module.py (awesome!)
Swift 5.3.2 1.395 recursive (xcode release scheme)
C clang 12.0.0 1.295 faster using uint64_t clang -O3 fib.c -o fib
Zig 0.8.0 1.484 faster using u64 zig build-exe fib.zig -O ReleaseSafe
V 0.2.2 2.310 faster using u64 v -autofree fib.v
Nim 1.4.4 1.515 recursive nim c -d:release fib.nim
Repository

fib

Owner
Statistic
  • 0
  • 0
  • 0
  • 0
  • 0
  • over 3 years ago
  • March 21, 2021
License

MIT License

Links
Synced at

Thu, 07 Nov 2024 02:07:50 GMT

Languages