summaryrefslogtreecommitdiff
path: root/stddev
blob: 3bf0270c3a3428c31dc3a2a80ff8b9742ce45cca (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
35
36
37
38
39
40
41
#!/usr/bin/env ruby

require 'trollop'


def usage
  STDERR.write "./stddev [-r <d>] < <one number per line>\n"
  exit 1
end
usage if not [0,2].include? ARGV.size

opts = Trollop::options do
  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.strip.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)

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