File: variance.yml

package info (click to toggle)
ruby-enumerable-statistics 2.0.1%2Bdfsg-3
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 1,036 kB
  • sloc: ansic: 1,808; ruby: 679; makefile: 11; sh: 4
file content (39 lines) | stat: -rw-r--r-- 731 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
contexts:
  - name: "master"
    prelude: |-
      require 'bundler/setup'
      require 'enumerable/statistics'
prelude: |-
  n = 1000
  ary = Array.new(n) { rand }
benchmark:
  inject: |-
    mean = ary.mean
    var = ary.inject(0.0) { |sum, x|
      sum += (x - mean) ** 2
    } / (n - 1).to_f
  while: |-
    mean = ary.mean
    i, var = 0, 0
    while i < n
      var += (ary[i] - mean) ** 2
      i += 1
    end
    var /= n.to_f
  pure_ruby: |-
    i, m, m2, f, c = 0, 0.0, 0.0, 0.0, 0.0
    while i < n
      x = ary[i]
      y = x - c
      t = f + y
      c = (t - f) - y
      f = t

      delta = x - m
      m += delta / i
      m2 += delta * (x - m)

      i += 1
    end
    var = m2 / n
  c_ext: var = ary.variance