File: calc_insert.py

package info (click to toggle)
vg 1.30.0%2Bds-1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 267,848 kB
  • sloc: cpp: 446,974; ansic: 116,148; python: 22,805; cs: 17,888; javascript: 11,031; sh: 5,866; makefile: 4,039; java: 1,415; perl: 1,303; xml: 442; lisp: 242
file content (30 lines) | stat: -rwxr-xr-x 768 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
import sys
import math

# run with::
# ./bin/vg view -a alt.mega.gam | grep -o "\"length\": [-]*[0-9]*" | cut -f 2 -d ":" | python scripts/calc_insert.py

def calc_mean(vals):
    return float(sum(vals)) / float(len(vals))

def calc_sd(vals, mean):
    sq_err_sum = 0.0
    for i in vals:
        sq_err_sum += (float(i) - mean) ** 2

    return  math.sqrt( (1.0 / float(len(vals))) * sq_err_sum)

if __name__ == "__main__":

    vals = []
    for line in sys.stdin:
        x = float(line.strip())
        if x > 0:
            vals.append(x);
        else:
            vals.append(-1.0 * x)
        if len(vals) == 1000:
            mean = calc_mean(vals)
            sd = calc_sd(vals, mean)
            print("Mean: ", mean, ",  SD: ", sd)
            del vals[:]