From 9a324cf9cc553f77ddbac5de815768cb1655cfe9 Mon Sep 17 00:00:00 2001 From: samuel Date: Tue, 20 Nov 2018 10:13:51 +0000 Subject: Better benchmark name. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@65845 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- benchmark/bm_vm2_fiber_chain.rb | 50 ----------------------------------------- benchmark/vm2_fiber_chain.rb | 50 +++++++++++++++++++++++++++++++++++++++++ 2 files changed, 50 insertions(+), 50 deletions(-) delete mode 100755 benchmark/bm_vm2_fiber_chain.rb create mode 100755 benchmark/vm2_fiber_chain.rb diff --git a/benchmark/bm_vm2_fiber_chain.rb b/benchmark/bm_vm2_fiber_chain.rb deleted file mode 100755 index 7d5b561229..0000000000 --- a/benchmark/bm_vm2_fiber_chain.rb +++ /dev/null @@ -1,50 +0,0 @@ -#!/usr/bin/env ruby - -require 'benchmark' - -def make_link(previous) - Fiber.new do - while message = previous.resume - Fiber.yield(message) - end - end -end - -def make_chain(length, &block) - chain = Fiber.new(&block) - - (length - 1).times do - chain = make_link(chain) - end - - return chain -end - -def run_benchmark(length, repeats, message = :hello) - chain = nil - - time = Benchmark.realtime do - chain = make_chain(length) do - while true - Fiber.yield(message) - end - end - end - - puts "Creating #{fibers} fibers took #{time}..." - - time = Benchmark.realtime do - repeats.times do - abort "invalid result" unless chain.resume == message - end - end - - puts "Passing #{repeats} messages took #{time}..." -end - -n = (ARGV[0] || 1000).to_i -m = (ARGV[1] || 1000).to_i - -5.times do - run_benchmark(n, m) -end diff --git a/benchmark/vm2_fiber_chain.rb b/benchmark/vm2_fiber_chain.rb new file mode 100755 index 0000000000..7d5b561229 --- /dev/null +++ b/benchmark/vm2_fiber_chain.rb @@ -0,0 +1,50 @@ +#!/usr/bin/env ruby + +require 'benchmark' + +def make_link(previous) + Fiber.new do + while message = previous.resume + Fiber.yield(message) + end + end +end + +def make_chain(length, &block) + chain = Fiber.new(&block) + + (length - 1).times do + chain = make_link(chain) + end + + return chain +end + +def run_benchmark(length, repeats, message = :hello) + chain = nil + + time = Benchmark.realtime do + chain = make_chain(length) do + while true + Fiber.yield(message) + end + end + end + + puts "Creating #{fibers} fibers took #{time}..." + + time = Benchmark.realtime do + repeats.times do + abort "invalid result" unless chain.resume == message + end + end + + puts "Passing #{repeats} messages took #{time}..." +end + +n = (ARGV[0] || 1000).to_i +m = (ARGV[1] || 1000).to_i + +5.times do + run_benchmark(n, m) +end -- cgit v1.2.3