Sha256: baaf4280064e8c762e99464c6d67177de948253b6c9636603e940d811f157e77

Contents?: true

Size: 1.22 KB

Versions: 6

Compression:

Stored size: 1.22 KB

Contents

#!/usr/bin/env ruby
# example to explain hold! usage https://github.com/evanphx/benchmark-ips/issues/85
# The hold! feature expects to be run twice, generally with different Rubys.
# hold! can also be used to compare modules changes which impact the run time
# RUN_1: ruby examples/hold.rb
# Warming up --------------------------------------
#             without   172.168k i/100ms
# Calculating -------------------------------------
#             without      2.656M (± 3.3%) i/s -     13.429M in   5.062098s
#
# RUN_2: WITH_MODULE=true ruby examples/hold.rb
# Warming up --------------------------------------
#                 with    92.087k i/100ms
# Calculating -------------------------------------
#                 with      1.158M (± 1.4%) i/s -      5.801M in   5.010084s
#
# Comparison:
#              without:  2464721.3 i/s
#                 with:  1158179.6 i/s - 2.13x  slower
require 'benchmark/ips'

Benchmark.ips do |x|
  x.report('without') do
    'Bruce'.inspect
  end

  if ENV['WITH_MODULE'] == 'true'
    class String
      def inspect
        result = %w[Bruce Wayne is Batman]
        result.join(' ')
      end
    end
  end

  x.report('with') do
    'Bruce'.inspect
  end
  x.hold! 'temp_results'
  x.compare!
end

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
benchmark-ips-2.14.0 examples/hold.rb
benchmark-ips-2.13.0 examples/hold.rb
benchmark-ips-2.12.0 examples/hold.rb
benchmark-ips-2.11.0 examples/hold.rb
benchmark-ips-2.10.0 examples/hold.rb
benchmark-ips-2.9.3 examples/hold.rb