forked from rrenaud/dominionstats
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathtest_stats.py
37 lines (27 loc) · 1.01 KB
/
test_stats.py
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
#!/usr/bin/python
import unittest
import stats
class RandomVariableStat(unittest.TestCase):
def test_simple(self):
d = stats.MeanVarStat()
d.add_outcome(2.) # freq = 1, sum = 2, sum_sq = 4
d.add_outcome(3.) # freq = 2, sum = 5, sum_sq = 13
self.assertEquals(d.frequency(), 2)
self.assertEquals(d.mean(), 2.5)
self.assertEquals(d.variance(), (13 - 25. / 2) / 1)
def test_merge(self):
a = stats.MeanVarStat()
b = stats.MeanVarStat()
a.add_outcome(1)
b.add_outcome(1)
b.merge(a)
self.assertEquals(b.frequency(), 2)
class EmptySets(unittest.TestCase):
def test_no_occurrences(self):
d = stats.MeanVarStat()
self.assertEquals(d.mean(), float('inf'))
self.assertEquals(d.variance(), float('inf'))
self.assertEquals(d.std_dev(), float('inf'))
self.assertEquals(d.sample_std_dev(), float('inf'))
if __name__ == '__main__':
unittest.main()