Ejemplo n.º 1
0
 def test_toFreqs(self):
     """Histogram toFreqs() should return a Freqs object"""
     h = Histogram(list(range(0,20)),bins=[Span(0,3),Span(3,10),
         Span(10,18),Span(18,20)])
     constructor=str
     f = h.toFreqs()
     self.assertEqual(f[constructor(Span(0,3))],3)
     self.assertEqual(f[constructor(Span(3,10))],7)
     self.assertEqual(f[constructor(Span(10,18))],8)
     self.assertEqual(f[constructor(Span(18,20))],2)
Ejemplo n.º 2
0
 def test_toFreqs(self):
     """Histogram toFreqs() should return a Freqs object"""
     h = Histogram(range(0,20),bins=[Span(0,3),Span(3,10),
         Span(10,18),Span(18,20)])
     constructor=str
     f = h.toFreqs()
     self.assertEqual(f[constructor(Span(0,3))],3)
     self.assertEqual(f[constructor(Span(3,10))],7)
     self.assertEqual(f[constructor(Span(10,18))],8)
     self.assertEqual(f[constructor(Span(18,20))],2)
Ejemplo n.º 3
0
 def test_clear(self):
     """Histogram clear should reset all data"""
     data = [1,3,5,'A']
     bins = [Span(0,2),Span(2,4),Span(4,6)]
     data_and_bins = Histogram(data=data,bins=bins)
     self.assertEqual(data_and_bins._bins,bins)
     self.assertEqual(data_and_bins._values,[[1],[3],[5]])
     self.assertEqual(data_and_bins.Other,['A'])
     data_and_bins.clear()
     self.assertEqual(data_and_bins._values,[[],[],[]])
     self.assertEqual(data_and_bins.Other,[])
Ejemplo n.º 4
0
 def test_multi(self):
     """Histogram Multi should allow values to match multiple bins"""
     #bins, data, multi=True
     bins2 = [Span(0,5),Span(3,8),Span(6,10)]
     data2 = [0,1,2,3,4,5,6,7,8,9,10]
     not_multi = Histogram(data2,bins2)
     self.assertEqual(not_multi._values,[[0,1,2,3,4],[5,6,7],[8,9]])
     self.assertEqual(not_multi.Other,[10])
     multi = Histogram(data2,bins2,Multi=True)
     self.assertEqual(multi._values,[[0,1,2,3,4],[3,4,5,6,7],[6,7,8,9]])
     self.assertEqual(multi.Other,[10])
Ejemplo n.º 5
0
 def test_clear(self):
     """Histogram clear should reset all data"""
     data = [1,3,5,'A']
     bins = [Span(0,2),Span(2,4),Span(4,6)]
     data_and_bins = Histogram(data=data,bins=bins)
     self.assertEqual(data_and_bins._bins,bins)
     self.assertEqual(data_and_bins._values,[[1],[3],[5]])
     self.assertEqual(data_and_bins.Other,['A'])
     data_and_bins.clear()
     self.assertEqual(data_and_bins._values,[[],[],[]])
     self.assertEqual(data_and_bins.Other,[])
Ejemplo n.º 6
0
 def test_mapping(self):
     """Histogram Mapping should apply correct function to values"""
     # bins, data, mapping
     data = ['A','AAA','CCCCC','GGGGGGGGGGGGGG']
     bins = [Span(0,2),Span(2,4),Span(4,6)]
     mapping = Histogram(data=data,bins=bins,Mapping=len)
     self.assertEqual(mapping._values, [['A'],['AAA'],['CCCCC']])
     self.assertEqual(mapping.Other,['GGGGGGGGGGGGGG'])
Ejemplo n.º 7
0
 def test_call(self):
     """Histogram __call__ should update with new data"""
     data = [1,3,5,'A']
     bins = [Span(0,2),Span(2,4),Span(4,6)]
     data_and_bins = Histogram(data=data,bins=bins)
     #update the histogram
     data_and_bins([4,5,6,7])
     self.assertEqual(data_and_bins._values,[[1],[3],[5,4,5]])
     self.assertEqual(data_and_bins.Other,['A',6,7])
Ejemplo n.º 8
0
 def test_init_bins_data(self):
     """Histogram should fill bins with data if supplied"""
     # most basic histogram, bins and data
     data = [1,3,5,'A']
     bins = [Span(0,2),Span(2,4),Span(4,6)]
     data_and_bins = Histogram(data=data,bins=bins)
     self.assertEqual(data_and_bins._bins,bins)
     self.assertEqual(data_and_bins._values,[[1],[3],[5]])
     self.assertEqual(data_and_bins.Other,['A'])
Ejemplo n.º 9
0
 def test_init_bins(self):
     """Histogram should set _bins property correctly"""
     bins = [Span(0,2),Span(2,4),Span(4,6)]
     bins_only = Histogram(bins=bins)
     self.assertEqual(bins_only._bins, bins)