summaryrefslogtreecommitdiff
path: root/stddev
blob: a7397b2ae8f53e5784d81b74aec9c0729097141b (plain)
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
#!/usr/bin/env ruby

require 'trollop'

cfg = Trollop::options do
  banner "stddev [-r <d>] < <one number per line>"
  opt :round, "Number of digits after decimal point.", :type => :int, :default => -1
end

sum = 0.0
i = 0
cached = []
while line=STDIN.gets
  v = line.to_f
  sum += v
  cached << v
  i +=1
end

avg = sum/i.to_f

var = 0
cached.each { |v|
  var += (avg - v)**2
}

stddev = Math.sqrt(var/i.to_f)

if cfg[:round] >= 0
  puts stddev.round cfg[:round]
else
  puts stddev
end