File: bench_fib_chained.rb

package info (click to toggle)
jruby 1.5.6-9
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 45,088 kB
  • ctags: 77,093
  • sloc: ruby: 398,491; java: 170,202; yacc: 3,782; xml: 2,529; sh: 299; tcl: 40; makefile: 35; ansic: 23
file content (28 lines) | stat: -rw-r--r-- 535 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
require 'benchmark'

class Fib
  def fib_ruby(n)
    if n < 2
      n
    else
      fib5(n - 2) + fib5(n - 1)
    end
  end
  def fibx(n); fib_ruby(n); end
  alias_method :fib, :fibx
  def fib2x(n); fib(n); end
  alias_method :fib2, :fib2x
  def fib3x(n); fib2(n); end
  alias_method :fib3, :fib3x
  def fib4x(n); fib3(n); end
  alias_method :fib4, :fib4x
  def fib5x(n); fib4(n); end
  alias_method :fib5, :fib5x
end

TIMES = (ARGV[0] || 5).to_i
N = (ARGV[1] || 30).to_i
TIMES.times {
  puts Benchmark.measure { Fib.new.fib5(N) }
}