File: simple.rb

package info (click to toggle)
ruby-beefcake 1.2.0-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye, forky, sid, trixie
  • size: 196 kB
  • sloc: ruby: 1,655; makefile: 4
file content (116 lines) | stat: -rw-r--r-- 2,710 bytes parent folder | download | duplicates (2)
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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
$:.unshift File.expand_path('../../lib', __FILE__)
require 'beefcake'

class MyMessage
  include Beefcake::Message
  required :number, :int32,  1
  required :chars,  :string, 2
  required :raw,    :bytes,  3
  required :bool,   :bool,   4
  required :float,  :float,  5
end

ITERS = 100_000

case ARGV[0]
when 'pprof'
  # profile message creation/encoding/decoding w/ perftools.rb
  # works on 1.8 and 1.9
  #   ruby bench/simple.rb pprof
  #   open bench/beefcake.prof.gif

  ENV['CPUPROFILE_FREQUENCY'] = '4000'
  require 'rubygems'
  require 'perftools'
  PerfTools::CpuProfiler.start(File.expand_path("../beefcake.prof", __FILE__)) do
    ITERS.times do
      str = MyMessage.new(
        :number => 12345,
        :chars  => 'hello',
        :raw    => 'world',
        :bool   => true,
        :float  => 1.2345
      ).encode
      MyMessage.decode(str)
    end
  end
  Dir.chdir(File.dirname(__FILE__)) do
    `pprof.rb beefcake.prof --gif > beefcake.prof.gif`
  end

when 'ruby-prof'
  # profile message creation/encoding/decoding w/ ruby-prof
  # works on 1.8 and 1.9
  #   ruby bench/simple.rb ruby-prof
  #   open bench/beefcake.prof.html

  require 'ruby-prof'
  result = RubyProf.profile do
    ITERS.times do
      str = MyMessage.new(
        :number => 12345,
        :chars  => 'hello',
        :raw    => 'world',
        :bool   => true,
        :float  => 1.2345
      ).encode
      MyMessage.decode(str)
    end
  end

  filename = File.expand_path('beefcake.prof.html', File.dirname(__FILE__))
  File.open(filename, 'w') do |file|
    RubyProf::GraphHtmlPrinter.new(result).print(file)
  end

else
  # benchmark message creation/encoding/decoding
  #   rvm install 1.8.7 1.9.2 jruby rbx
  #   rvm 1.8.7,1.9.2,jruby,rbx ruby bench/simple.rb

  require 'benchmark'

  Benchmark.bmbm do |x|
    x.report 'object creation' do
      ITERS.times do
        Object.new
      end
    end
    x.report 'message creation' do
      ITERS.times do
        MyMessage.new(
          :number => 12345,
          :chars  => 'hello',
          :raw    => 'world',
          :bool   => true,
          :float  => 1.2345
        )
      end
    end
    x.report 'message encoding' do
      m = MyMessage.new(
        :number => 12345,
        :chars  => 'hello',
        :raw    => 'world',
        :bool   => true,
        :float  => 1.2345
      )
      ITERS.times do
        m.encode
      end
    end
    x.report 'message decoding' do
      str = MyMessage.new(
        :number => 12345,
        :chars  => 'hello',
        :raw    => 'world',
        :bool   => true,
        :float  => 1.2345
      ).encode.to_s
      ITERS.times do
        MyMessage.decode(str.dup)
      end
    end
  end

end