本文整理匯總了Python中cogent.core.profile.Profile.reduce方法的典型用法代碼示例。如果您正苦於以下問題:Python Profile.reduce方法的具體用法?Python Profile.reduce怎麽用?Python Profile.reduce使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類cogent.core.profile.Profile
的用法示例。
在下文中一共展示了Profile.reduce方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: test_reduce_operators
# 需要導入模塊: from cogent.core.profile import Profile [as 別名]
# 或者: from cogent.core.profile.Profile import reduce [as 別名]
def test_reduce_operators(self):
"""reduce: should work fine with different operators
"""
# different operators, normalize input, don't normalize output
p1 = Profile(array([[1, 0, 0], [0, 1, 0]]), Alphabet="ABC")
p2 = Profile(array([[1, 0, 0], [0, 0, 1]]), Alphabet="ABC")
self.assertEqual(p1.reduce(p2).Data, array([[1, 0, 0], [0, 0.5, 0.5]]))
self.assertEqual(
p1.reduce(p2, add, normalize_input=True, normalize_output=False).Data, array([[2, 0, 0], [0, 1, 1]])
)
self.assertEqual(
p1.reduce(p2, subtract, normalize_input=True, normalize_output=False).Data, array([[0, 0, 0], [0, 1, -1]])
)
self.assertEqual(
p1.reduce(p2, multiply, normalize_input=True, normalize_output=False).Data, array([[1, 0, 0], [0, 0, 0]])
)
self.assertRaises(ProfileError, p1.reduce, p2, divide, normalize_input=True, normalize_output=False)
# don't normalize and normalize only input
p3 = Profile(array([[1, 2], [3, 4]]), Alphabet="AB")
p4 = Profile(array([[4, 3], [2, 1]]), Alphabet="AB")
self.assertEqual(
p3.reduce(p4, add, normalize_input=False, normalize_output=False).Data, array([[5, 5], [5, 5]])
)
self.assertFloatEqual(
p3.reduce(p4, add, normalize_input=True, normalize_output=False).Data,
array([[19 / 21, 23 / 21], [23 / 21, 19 / 21]]),
)
# normalize input and output
p5 = Profile(array([[1, 1, 0, 0], [1, 1, 1, 1]]), Alphabet="ABCD")
p6 = Profile(array([[1, 0, 0, 0], [1, 0, 0, 1]]), Alphabet="ABCD")
self.assertEqual(
p5.reduce(p6, add, normalize_input=True, normalize_output=True).Data,
array([[0.75, 0.25, 0, 0], [0.375, 0.125, 0.125, 0.375]]),
)
# it can collapse empty profiles when normalizing is turned off
self.assertEqual(
self.empty.reduce(self.empty, normalize_input=False, normalize_output=False).Data.tolist(), [[]]
)
示例2: ProfileTests
# 需要導入模塊: from cogent.core.profile import Profile [as 別名]
# 或者: from cogent.core.profile.Profile import reduce [as 別名]
#.........這裏部分代碼省略.........
# it will still print with invalid data (e.g if len(CharOrder)
# doesn't match the data
p = self.full.copy()
p.CharOrder = "ABC"
self.assertEqual(p.prettyPrint(include_header=True), "A\tB\tC\n2\t4\t \n3\t5\t \n4\t8\t ")
# it will truncate the CharOrder if data is transposed
# and CharOrder is longer then the number of rows in the
# transposed data
self.assertEqual(p.prettyPrint(include_header=True, transpose_data=True), "A\t2\t3\t4\nB\t4\t5\t8")
def test_prettyPrint_four_cases(self):
"""prettyPrint: with/without header/transpose/limit"""
p = self.full
p = self.pp
self.assertEqual(p.prettyPrint(), "1\t 2\t 3\t 4\n5\t 6\t 7\t 8\n9\t10\t11\t12")
self.assertEqual(p.prettyPrint(column_limit=3), "1\t 2\t 3\n5\t 6\t 7\n9\t10\t11")
self.assertEqual(
p.prettyPrint(column_limit=3, include_header=True), "A\t B\t C\n1\t 2\t 3\n5\t 6\t 7\n9\t10\t11"
)
self.assertEqual(
p.prettyPrint(column_limit=3, include_header=False, transpose_data=True),
"1\t5\t 9\n2\t6\t10\n3\t7\t11\n4\t8\t12",
)
self.assertEqual(
p.prettyPrint(column_limit=2, include_header=False, transpose_data=True), "1\t5\n2\t6\n3\t7\n4\t8"
)
self.assertEqual(
p.prettyPrint(column_limit=3, include_header=True, transpose_data=True),
"A\t1\t5\nB\t2\t6\nC\t3\t7\nD\t4\t8",
)
def test_reduce_wrong_size(self):
"""reduce: should fail when profiles have different sizes"""
p1 = Profile(array([[1, 0], [0, 1]]), Alphabet="AB")
p2 = Profile(array([[1, 0, 0], [1, 0, 0]]), Alphabet="ABC")
self.assertRaises(ProfileError, p1.reduce, p2)
def test_reduce_normalization_error(self):
"""reduce: fails when input or output can't be normalized"""
# Will raise errors when input data can't be normalized
self.assertRaises(ProfileError, self.empty.reduce, self.empty, add)
self.assertRaises(ProfileError, self.full.reduce, self.empty_row, add)
# don't normalize input, but do normalize output
# fails when one row adds up to zero
p1 = Profile(array([[3, 3], [4, 4]]), "AB")
p2 = Profile(array([[3, 3], [-4, -4]]), "AB")
self.assertRaises(ProfileError, p1.reduce, p2, add, False, True)
def test_reduce_operators(self):
"""reduce: should work fine with different operators
"""
# different operators, normalize input, don't normalize output
p1 = Profile(array([[1, 0, 0], [0, 1, 0]]), Alphabet="ABC")
p2 = Profile(array([[1, 0, 0], [0, 0, 1]]), Alphabet="ABC")
self.assertEqual(p1.reduce(p2).Data, array([[1, 0, 0], [0, 0.5, 0.5]]))
self.assertEqual(
p1.reduce(p2, add, normalize_input=True, normalize_output=False).Data, array([[2, 0, 0], [0, 1, 1]])
)
self.assertEqual(
p1.reduce(p2, subtract, normalize_input=True, normalize_output=False).Data, array([[0, 0, 0], [0, 1, -1]])
)
self.assertEqual(