Class: Metriks::Histogram

Inherits:
Object
  • Object
show all
Defined in:
lib/metriks/histogram.rb

Constant Summary collapse

DEFAULT_SAMPLE_SIZE =
1028
DEFAULT_ALPHA =
0.015

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(sample) ⇒ Histogram

Returns a new instance of Histogram.



18
19
20
21
22
23
24
25
# File 'lib/metriks/histogram.rb', line 18

def initialize(sample)
  @sample   = sample
  @count    = Atomic.new(0)
  @min      = Atomic.new(nil)
  @max      = Atomic.new(nil)
  @sum      = Atomic.new(0)
  @variance = Atomic.new([ -1, 0 ])
end

Class Method Details

.new_exponentially_decayingObject



14
15
16
# File 'lib/metriks/histogram.rb', line 14

def self.new_exponentially_decaying
  new(Metriks::ExponentiallyDecayingSample.new(DEFAULT_SAMPLE_SIZE, DEFAULT_ALPHA))
end

.new_uniformObject



10
11
12
# File 'lib/metriks/histogram.rb', line 10

def self.new_uniform
  new(Metriks::UniformSample.new(DEFAULT_SAMPLE_SIZE))
end

Instance Method Details

#clearObject



27
28
29
30
31
32
33
34
# File 'lib/metriks/histogram.rb', line 27

def clear
  @sample.clear
  @count.value = 0
  @min.value = nil
  @max.value = nil
  @sum.value = 0
  @variance.value = [ -1, 0 ]
end

#countObject



49
50
51
# File 'lib/metriks/histogram.rb', line 49

def count
  @count.value
end

#maxObject



57
58
59
# File 'lib/metriks/histogram.rb', line 57

def max
  count > 0 ? @max.value : 0.0
end

#max=(potential_max) ⇒ Object



77
78
79
80
81
82
83
84
# File 'lib/metriks/histogram.rb', line 77

def max=(potential_max)
  done = false

  while !done
    current_max = @max.value
    done = (!current_max.nil? && current_max >= potential_max) || @max.compare_and_swap(current_max, potential_max)
  end
end

#meanObject



65
66
67
# File 'lib/metriks/histogram.rb', line 65

def mean
  count > 0 ? @sum.value / count : 0.0
end

#minObject



61
62
63
# File 'lib/metriks/histogram.rb', line 61

def min
  count > 0 ? @min.value : 0.0
end

#min=(potential_min) ⇒ Object



86
87
88
89
90
91
92
93
# File 'lib/metriks/histogram.rb', line 86

def min=(potential_min)
  done = false

  while !done
    current_min = @min.value
    done = (!current_min.nil? && current_min <= potential_min) || @min.compare_and_swap(current_min, potential_min)
  end
end

#snapshotObject



45
46
47
# File 'lib/metriks/histogram.rb', line 45

def snapshot
  @sample.snapshot
end

#stddevObject



69
70
71
# File 'lib/metriks/histogram.rb', line 69

def stddev
  count > 0 ? variance ** 0.5 : 0.0
end

#sumObject



53
54
55
# File 'lib/metriks/histogram.rb', line 53

def sum
  @sum.value
end

#update(value) ⇒ Object



36
37
38
39
40
41
42
43
# File 'lib/metriks/histogram.rb', line 36

def update(value)
  @count.update { |v| v + 1 }
  @sample.update(value)
  self.max = value
  self.min = value
  @sum.update { |v| v + value }
  update_variance(value)
end

#update_variance(value) ⇒ Object



95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
# File 'lib/metriks/histogram.rb', line 95

def update_variance(value)
  @variance.update do |old_values|
    new_values = Array.new(2)
    if old_values[0] == -1
      new_values[0] = value
      new_values[1] = 0
    else
      old_m = old_values[0]
      old_s = old_values[1]

      new_m = old_m + ((value - old_m) / count)
      new_s = old_s + ((value - old_m) * (value - new_m))

      new_values[0] = new_m
      new_values[1] = new_s
    end

    new_values
  end
end

#varianceObject



73
74
75
# File 'lib/metriks/histogram.rb', line 73

def variance
  count <= 1 ? 0.0 : @variance.value[1] / (count - 1)
end