當前位置: 首頁>>代碼示例>>Python>>正文


Python usage.BaseUsage類代碼示例

本文整理匯總了Python中cogent.core.usage.BaseUsage的典型用法代碼示例。如果您正苦於以下問題:Python BaseUsage類的具體用法?Python BaseUsage怎麽用?Python BaseUsage使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


在下文中一共展示了BaseUsage類的14個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: test_positionalBases

 def test_positionalBases(self):
     """BaseUsage positionalBases should have copy of self at each position"""
     b = BaseUsage('A')
     p = b.positionalBases()
     for i in p:
         assert i is not b
         self.assertEqual(i, {'A':1,'U':0,'C':0,'G':0})
開發者ID:GavinHuttley,項目名稱:pycogent,代碼行數:7,代碼來源:test_usage.py

示例2: test_setitem

 def test_setitem(self):
     """BaseUsage should map keys on setitem"""
     b = BaseUsage()
     b['t'] = 3
     b['G'] = 3
     b.normalize()
     i = b.items()
     i.sort()
     self.assertEqual(i, [('A',0.0),('C',0.0),('G',0.5),('U',0.5)])
開發者ID:GavinHuttley,項目名稱:pycogent,代碼行數:9,代碼來源:test_usage.py

示例3: test_fromCartesian

 def test_fromCartesian(self):
     """BaseUsage fromCartesian should init instance from x,y,z"""
     b = BaseUsage.fromCartesian(0.5,.5,.5)
     self.assertFloatEqual(b['A'], 0.25)
     self.assertFloatEqual(b['C'], 0.25)
     self.assertFloatEqual(b['G'], 0.25)
     self.assertFloatEqual(b['U'], 0.25)
     b = BaseUsage.fromCartesian(1/3.0, 1/3.0, 1/3.0)
     self.assertEqual(b['U'], 0)
     self.assertEqual(b['A'], 1/3.0)
開發者ID:GavinHuttley,項目名稱:pycogent,代碼行數:10,代碼來源:test_usage.py

示例4: test_getitem

 def test_getitem(self):
     """BaseUsage should map key on getitem"""
     b = BaseUsage({'a':3, 'T':2, 'X':1})
     self.assertEqual(b['X'], 1)
     self.assertEqual(b['A'], 3)
     self.assertEqual(b['U'], 2)
     self.assertEqual(b['a'], 3)
     self.assertEqual(b['t'], 2)
     b.normalize()
     assert 'X' not in b
     self.assertFloatEqual(b['A'], 0.6)
     self.assertFloatEqual(b['u'], 0.4)
開發者ID:GavinHuttley,項目名稱:pycogent,代碼行數:12,代碼來源:test_usage.py

示例5: test_init_empty

    def test_init_empty(self):
        """BaseUsage should init with empty freqs"""
        b = BaseUsage()
        self.assertEqual(len(b), 4)
        for nt in 'UTACGutacg':
            assert nt in b
            self.assertEqual(b[nt], 0)
        for nt in 'UCAG':
            assert nt in b.keys()

        items = list(iter(b))
        items.sort()
        self.assertEqual(items, ['A', 'C', 'G', 'U'])
開發者ID:GavinHuttley,項目名稱:pycogent,代碼行數:13,代碼來源:test_usage.py

示例6: test_distance

 def test_distance(self):
     """BaseUsage distance() should return dist between two BUs"""
     #absolute numbers, will normalize to calculate distance
     self.assertFloatEqual(BaseUsage('GC').distance(BaseUsage('AU')),1)
     self.assertFloatEqual(BaseUsage('AU').distance(BaseUsage('GC')),1)
     self.assertFloatEqual(BaseUsage('GCAU').distance(BaseUsage('AUAU')),.5)
     #should work even against dict with 'T's
     self.assertFloatEqual(BaseUsage('GCAU').distance(\
         BaseUsage({'A':2,'T':2,'C':0,'G':0,})),.5)
     #rounding error
     self.assertEqual(BaseUsage('ACG').distance(BaseUsage('CCGGAA')),0)
     #normalized - as in unit simplex
     ag = BaseUsage('AG')
     ag.normalize()
     uc = BaseUsage('UC')
     uc.normalize()
     self.assertFloatEqual(ag.distance(uc),1)
     self.assertFloatEqual(BaseUsage({'A':0.4,'G':0.1,'C':0.4,'U':0.1})\
     .distance(BaseUsage({'A':0.1,'G':0.4,'U':0.4,'C':0.1})),0.6)
     self.assertFloatEqual(BaseUsage({'A':0.25,'G':0.25,'C':0.25,'U':0.25})\
         .distance(BaseUsage({'A':0.25,'G':0.25,'U':0.25,'C':0.25})),0.0)
     self.assertFloatEqual(BaseUsage({'A':0.245,'G':0.255,'C':0.245,\
         'U':0.255}).distance(BaseUsage({'A':0.255,'G':0.245,'U':0.245,\
         'C':0.255})),0.02)
     self.assertFloatEqual(BaseUsage({'A':0.245,'G':0.255,'C':0.245,\
         'U':0.255}).distance(BaseUsage({'A':0.25,'G':0.25,'U':0.25,\
         'C':0.25})),0.01)
     self.assertFloatEqual(BaseUsage({'A':0.248,'G':0.252,'C':0.248,\
         'U':0.252}).distance(BaseUsage({'A':0.25,'G':0.25,'U':0.25,\
         'C':0.25})),0.004)
開發者ID:GavinHuttley,項目名稱:pycogent,代碼行數:30,代碼來源:test_usage.py

示例7: test_aminoAcids

 def test_aminoAcids(self):
     """BaseUsage aminoAcids should give the same results as the codons"""
     known_data = {
         'AAA' : .6 * .6 * .6,
         'AAU' : .6 * .6 * .4,
         'AUA' : .6 * .4 * .6,
         'AUU' : .6 * .4 * .4,
         'UAA' : .4 * .6 * .6,
         'UAU' : .4 * .6 * .4,
         'UUA' : .4 * .4 * .6,
         'UUU' : .4 * .4 * .4,
     }
     known = CodonUsage(known_data)
     b = BaseUsage({'a':3, 'T':2, 'X':1})
     self.assertEqual(b.aminoAcids(), known.aminoAcids())
     #check that the genetic code is passed through correctly
     all_g = GeneticCode('G'*64)
     self.assertEqual(b.aminoAcids(all_g), AminoAcidUsage({'G':1}))
開發者ID:GavinHuttley,項目名稱:pycogent,代碼行數:18,代碼來源:test_usage.py

示例8: test_codons

 def test_codons(self):
     """BaseUsage codons should return most likely codon freqs"""
     b = BaseUsage({'a':3, 'T':2, 'X':1})
     c = b.codons()
     known = {
         'AAA' : .6 * .6 * .6,
         'AAU' : .6 * .6 * .4,
         'AUA' : .6 * .4 * .6,
         'AUU' : .6 * .4 * .4,
         'UAA' : .4 * .6 * .6,
         'UAU' : .4 * .6 * .4,
         'UUA' : .4 * .4 * .6,
         'UUU' : .4 * .4 * .4,
     }
     for codon in c:
         if codon in known:
             self.assertFloatEqual(c[codon], known[codon])
         else:
             self.assertEqual(c[codon], 0)
開發者ID:GavinHuttley,項目名稱:pycogent,代碼行數:19,代碼來源:test_usage.py

示例9: test_toCartesian

 def test_toCartesian(self):
     """BaseUsage toCartesian should return x, y, z from instance"""
     b = BaseUsage('ACGU')
     self.assertEqual(b.toCartesian(), (0.5,0.5,0.5))
     b = BaseUsage('A')
     self.assertEqual(b.toCartesian(), (0,0,1))
     b = BaseUsage('CGA')
     self.assertEqual(b.toCartesian(), (1/3.0,1/3.0,1/3.0))
開發者ID:GavinHuttley,項目名稱:pycogent,代碼行數:8,代碼來源:test_usage.py

示例10: test_normalize

 def test_normalize(self):
     """BaseUsage normalize should work when empty"""
     b = BaseUsage()
     b.normalize()
     self.assertEqual(b, {'U':0,'C':0,'A':0,'G':0})
     b = BaseUsage('AACG')
     b.normalize()
     self.assertEqual(b, {'U':0, 'C':0.25, 'A':0.5, 'G':0.25})
開發者ID:GavinHuttley,項目名稱:pycogent,代碼行數:8,代碼來源:test_usage.py

示例11: test_content

 def test_content(self):
     """BaseUsage content should return sum of specified bases."""
     b = BaseUsage('UUUUUCCCAG')
     #should work for combinations
     self.assertEqual(b.content('UCAG'), 10)
     self.assertEqual(b.content('GC'), 4)
     self.assertEqual(b.content('AU'), 6)
     #should map T to U
     self.assertEqual(b.content('AT'), 6)
     #should work for single bases
     self.assertEqual(b.content('U'), 5)
     #shouldn't complain about invalid bases
     self.assertEqual(b.content('X'), 0)
開發者ID:GavinHuttley,項目名稱:pycogent,代碼行數:13,代碼來源:test_usage.py

示例12: test_bases

 def test_bases(self):
     """BaseUsage bases() should return same object"""
     b = BaseUsage({'a':3, 'T':2, 'C':5, 'X':1})
     c = b.bases()
     assert b is c
開發者ID:GavinHuttley,項目名稱:pycogent,代碼行數:5,代碼來源:test_usage.py

示例13: test_copy

 def test_copy(self):
     """BaseUsage copy should work correctly"""
     b = BaseUsage({'a':3, 'T':2, 'C':5, 'X':1})
     c = b.copy()
     self.assertEqual(c['AT'], 0.5)
開發者ID:GavinHuttley,項目名稱:pycogent,代碼行數:5,代碼來源:test_usage.py

示例14: test_init_data

 def test_init_data(self):
     """BaseUsage should init with arbitrary data"""
     b = BaseUsage('UUUUUGGGCA')
     self.assertEqual(b, {'U':5, 'G':3, 'C':1, 'A':1})
     b.normalize()
     self.assertEqual(b, {'U':0.5, 'G':0.3, 'C':0.1, 'A':0.1})
開發者ID:GavinHuttley,項目名稱:pycogent,代碼行數:6,代碼來源:test_usage.py


注:本文中的cogent.core.usage.BaseUsage類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。