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 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78
|
require File.expand_path(File.join(File.dirname(__FILE__), "bench_helper"))
module LibTest
extend FFI::Library
ffi_lib LIBTEST_PATH
callback :closureVrV, [ ], :void
attach_function :ffi_bench, :testClosureVrV, [ :closureVrV ], :void
@blocking = true
attach_function :threaded_bench, :testThreadedClosureVrV, [ :closureVrV, :int ], :void
def self.rb_bench(&block)
yield
end
end
unless RUBY_PLATFORM == "java" && JRUBY_VERSION < "1.3.0"
require 'dl'
require 'dl/import'
module LibTest
if RUBY_VERSION >= "1.9.0"
extend DL::Importer
else
extend DL::Importable
end
dlload LIBTEST_PATH
extern "int returnInt()"
end
end
puts "Benchmark [ ], :void closure block performance, #{ITER}x calls"
10.times {
puts Benchmark.measure {
ITER.times { LibTest.ffi_bench { } }
}
}
puts "Benchmark [ ], :void pre-allocated function pointer performance, #{ITER}x calls"
10.times {
fn = FFI::Function.new(:void, []) {}
puts Benchmark.measure {
ITER.times { LibTest.ffi_bench fn }
}
}
puts "Benchmark [ ], :void pre-allocated closure performance, #{ITER}x calls"
10.times {
proc = lambda {}
puts Benchmark.measure {
ITER.times { LibTest.ffi_bench proc }
}
}
puts "Benchmark [ ], :void non-ruby thread closure performance, #{ITER}x calls"
10.times {
fn = FFI::Function.new(:void, []) {}
puts Benchmark.measure {
LibTest.threaded_bench(fn, ITER)
}
}
#unless RUBY_PLATFORM == "java" && JRUBY_VERSION < "1.3.0"
#puts "Benchmark DL void bench() performance, #{ITER}x calls"
#10.times {
# puts Benchmark.measure {
# ITER.times { LibTest.returnInt }
# }
#}
#end
puts "Benchmark ruby method(no arg) performance, #{ITER}x calls"
10.times {
puts Benchmark.measure {
ITER.times { LibTest.rb_bench {} }
}
}
|