Completed
Push — master ( ab9d67...7b5ebf )
by Xianshun
59s
created

ContingencyTable.get_column_total()   A

Complexity

Conditions 2

Size

Total Lines 6

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 2
c 0
b 0
f 0
dl 0
loc 6
rs 9.4285
1
from pysie.dsl.set import TernarySearchSet, TernarySearchTrie
2
3
4
class ContingencyTable(object):
5
    values = None
6
    rows = None
7
    columns = None
8
9
    def __init__(self):
10
        self.rows = TernarySearchSet()
11
        self.columns = TernarySearchSet()
12
        self.values = TernarySearchTrie()
13
14
    def set_cell(self, row_name, column_name, value):
15
        key = self.make_key(row_name, column_name)
16
        self.values.put(key, value)
17
        self.rows.add(row_name)
18
        self.columns.add(column_name)
19
20
    def get_cell(self, row_name, column_name):
21
        key = self.make_key(row_name, column_name)
22
        if not self.values.contains_key(key):
23
            return 0
24
        return self.values.get(key)
25
26
    def make_key(self, row_name, column_name):
27
        return row_name + '-' + column_name
28
29
    def get_row_total(self, row_name):
30
        column_names = self.columns.to_array()
31
        result = 0
32
        for x in column_names:
33
            result += self.get_cell(row_name, x)
34
        return result
35
36
    def get_column_total(self, column_name):
37
        row_names = self.rows.to_array()
38
        result = 0
39
        for x in row_names:
40
            result += self.get_cell(x, column_name)
41
        return result
42
43
    def get_total(self):
44
        values = self.values.values()
45
        result = 0
46
        for val in values:
47
            result += val
48
        return result
49
50
51