2015-11-20 19:13:21 +02:00
|
|
|
require "benchmark"
|
|
|
|
class Stats
|
|
|
|
|
|
|
|
def initialize
|
|
|
|
@n = 0
|
|
|
|
@mean = 0.0
|
|
|
|
@variance = 0.0
|
|
|
|
end
|
|
|
|
attr_reader :n , :mean , :variance
|
|
|
|
|
|
|
|
def add(x)
|
|
|
|
@n = @n + 1
|
|
|
|
delta = x - @mean
|
|
|
|
@mean = @mean + delta/@n
|
|
|
|
@variance = @variance + delta*(x - @mean)
|
|
|
|
end
|
|
|
|
def show
|
2015-11-20 20:13:35 +02:00
|
|
|
#puts "no per var"
|
2015-11-20 23:51:58 +02:00
|
|
|
|
|
|
|
puts "#{@n} #{@mean} #{@variance / @n}"
|
2015-11-20 19:13:21 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
class Runner
|
2015-11-20 20:13:35 +02:00
|
|
|
def initialize
|
2015-11-20 19:13:21 +02:00
|
|
|
@stats = Stats.new
|
2015-11-24 15:33:16 +02:00
|
|
|
@cmd = ARGV.join(" ")
|
2015-11-20 19:13:21 +02:00
|
|
|
end
|
|
|
|
def run
|
2015-11-20 23:51:58 +02:00
|
|
|
while true
|
|
|
|
once
|
|
|
|
end
|
2015-11-20 19:13:21 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
def once
|
|
|
|
GC.disable
|
2015-11-20 23:51:58 +02:00
|
|
|
took = Benchmark.measure { %x(#{@cmd} > /dev/null)}.real
|
2015-11-20 19:13:21 +02:00
|
|
|
GC.enable
|
|
|
|
@stats.add took
|
2015-11-20 20:13:35 +02:00
|
|
|
@stats.show
|
2015-11-20 19:13:21 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
Runner.new.run
|