|
1
|
|
|
import unittest |
|
2
|
|
|
|
|
3
|
|
|
from numpy.random.mtrand import normal |
|
4
|
|
|
|
|
5
|
|
|
from pysie.dsl.variable_independence_testing import Anova, ContingencyTable |
|
6
|
|
|
from pysie.stats.samples import Sample |
|
7
|
|
|
|
|
8
|
|
|
|
|
9
|
|
|
class AnovaUnitTest(unittest.TestCase): |
|
10
|
|
|
def test_anova(self): |
|
11
|
|
|
sample = Sample() |
|
12
|
|
|
|
|
13
|
|
|
mu1 = 1.0 |
|
14
|
|
|
sigma1 = 1.0 |
|
15
|
|
|
|
|
16
|
|
|
mu2 = 1.1 |
|
17
|
|
|
sigma2 = 1.0 |
|
18
|
|
|
|
|
19
|
|
|
mu3 = 1.09 |
|
20
|
|
|
sigma3 = 1.0 |
|
21
|
|
|
|
|
22
|
|
|
for i in range(100): |
|
23
|
|
|
sample.add_numeric(normal(mu1, sigma1), 'group1') |
|
24
|
|
|
sample.add_numeric(normal(mu2, sigma2), 'group2') |
|
25
|
|
|
sample.add_numeric(normal(mu3, sigma3), 'group3') |
|
26
|
|
|
|
|
27
|
|
|
testing = Anova(sample=sample) |
|
28
|
|
|
|
|
29
|
|
|
print('p-value: ' + str(testing.p_value)) |
|
30
|
|
|
reject = testing.will_reject(0.01) |
|
31
|
|
|
print('will reject [same mean for all groups] ? ' + str(reject)) |
|
32
|
|
|
self.assertFalse(reject) |
|
33
|
|
|
|
|
34
|
|
|
|
|
35
|
|
|
class ContingencyTableUnitTest(unittest.TestCase): |
|
36
|
|
|
def test_table(self): |
|
37
|
|
|
table = ContingencyTable() |
|
38
|
|
|
table.set_cell('eventA', 'eventB', 10) |
|
39
|
|
|
table.set_cell('eventC', 'eventB', 20) |
|
40
|
|
|
table.set_cell('eventA', 'eventD', 15) |
|
41
|
|
|
table.set_cell('eventC', 'eventD', 10) |
|
42
|
|
|
|
|
43
|
|
|
print(table.get_column_total('eventB')) |
|
44
|
|
|
self.assertEqual(table.get_column_total('eventB'), 30) |
|
45
|
|
|
print(table.get_column_total('eventD')) |
|
46
|
|
|
self.assertEqual(table.get_column_total('eventD'), 25) |
|
47
|
|
|
print(table.get_row_total('eventA')) |
|
48
|
|
|
self.assertEqual(table.get_row_total('eventA'), 25) |
|
49
|
|
|
print(table.get_row_total('eventC')) |
|
50
|
|
|
self.assertEqual(table.get_row_total('eventC'), 30) |
|
51
|
|
|
self.assertEqual(table.get_total(), 55) |
|
52
|
|
|
|
|
53
|
|
|
|
|
54
|
|
|
if __name__ == '__main__': |
|
55
|
|
|
unittest.main() |
|
56
|
|
|
|