File: coverage.ll

package info (click to toggle)
lifelines 3.0.37.2-3
  • links: PTS
  • area: main
  • in suites: sarge
  • size: 8,312 kB
  • ctags: 6,091
  • sloc: ansic: 52,969; xml: 7,212; sh: 4,382; makefile: 724; yacc: 591; perl: 170; sed: 16
file content (85 lines) | stat: -rw-r--r-- 2,881 bytes parent folder | download
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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
/*
 * @progname       coverage
 * @version        3.0
 * @author         Wetmore, Woodbridge, Eggert
 * @category       
 * @output         Text
 * @description    
 *

   Displays "ancestor coverage," that is, what percentage of
   ancestors have been discovered for each generation back in time.

   First version by T. Wetmore, 21 February 1994
   2nd   version by S. Woodbridge, 6 March 1994
   3rd   version by J. Eggert, 7 March 1994
*/

proc main ()
{
        getindi(indi0, "Enter person to compute ancestor coverage for.")
        print("Collecting data .... \n")
        list(ilist)
        list(glist)
        list(garray)
        table(dtable)
        list(darray)
        enqueue(ilist, indi0)
        enqueue(glist, 1)
        while(indi, dequeue(ilist)) {
                set(gen, dequeue(glist))
                set(i, getel(garray, gen))
                set(i, add(i, 1))
                setel(garray, gen, i)
                if (not(lookup(dtable, key(indi)))) {
                        insert(dtable, key(indi), gen)
                        set(i, getel(darray, gen))
                        set(i, add(i, 1))
                        setel(darray, gen, i)
                }
/*                print(name(indi), "\n")       */
                if (par,father(indi)) {
                        enqueue(ilist, par)
                        enqueue(glist, add(1, gen))
                }
                if (par,mother(indi)) {
                        enqueue(ilist, par)
                        enqueue(glist, add(1, gen))
                }
        }
        set(i, 1)
        set(tot, 1)
        set(num, getel(garray, i))
        set(dnum, getel(darray, i))
        set(numsum, num)
        set(dnumsum, dnum)
        "Ancestor Coverage Table for " name(indi0) "\n\n"
        col(1) "Gen" col(6) "Total" col(16) "Found"
        col(26) "(Diff)" col(38) "Percentage\n\n"
        while (num) {
                col(1) d(sub(i, 1))
                col(6) if (lt(i,31)) { d(tot) }
                col(16) d(num)
                if (ne(num, dnum)) { col(26) "(" d(dnum) ")" }
                if (lt(i,31)) { col(38)
                        set(u, mul(num, 100))
                        set(q, div(u, tot))
                        set(m, mod(u, tot))
                        set(m, mul(m, 100))
                        set(m, div(m, tot))
                        d(q) "." if (lt(m, 10)) {"0"} d(m) " %"
                        set(tot, mul(tot, 2))
                }
                set(i, add(i, 1))
                set(num, getel(garray, i))
                set(dnum, getel(darray, i))
                set(numsum, add(numsum, num))
                set(dnumsum, add(dnumsum, dnum))
                print(d(i), "  ", d(num), "\n")
        }
        "\n\n"
        col(1) "all" col(16) d(numsum)
        if (ne(numsum, dnumsum)) { col(26) "(" d(dnumsum) ")" }
        "\n"
}