This repository was archived by the owner on May 11, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathterminal_output.py
74 lines (64 loc) · 2.61 KB
/
terminal_output.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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
# This file is part of sequence-aligner.
# Copyright (C) 2014 Christopher Kyle Horton <[email protected]>
# sequence-aligner is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
# sequence-aligner is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
# You should have received a copy of the GNU General Public License
# along with sequence-aligner. If not, see <http://www.gnu.org/licenses/>.
# MCS 5603 Intro to Bioinformatics, Fall 2014
# Christopher Kyle Horton (000516274), [email protected]
# Last modified: 11/6/2014
from scoring_matrix import ScoringMatrix
def print_bottom_border(columns):
'''Prints the bottom border of a table row.'''
output_row = "-+"
for column in range(0, columns):
output_row += "----+"
print output_row
def print_matrix(sm):
'''Prints the given ScoringMatrix to the terminal.'''
# Sequence on top
print "Dynamic programming table:"
output_row = " | |"
top_sequence = sm.get_top_sequence()
left_sequence = sm.get_left_sequence()
for c in top_sequence:
output_row += " " + c + "|"
print output_row
print_bottom_border(sm.get_columns())
# All other rows
for row in range(0, sm.get_rows()):
# Top half of row
output_row = " |"
for column in range(0, sm.get_columns()):
bl = sm.get_backlinks(row, column)
output_row += "\\ " if bl["diagonal"] else " "
output_row += "^ " if bl["up"] else " "
output_row += "|"
print output_row
# Bottom half of row
output_row = left_sequence[row - 1] if row >= 1 else " "
output_row += "|"
for column in range(0, sm.get_columns()):
bl = sm.get_backlinks(row, column)
output_row += "<" if bl["left"] else " "
output_row += "{0: >3}".format(sm.get_score(row, column))
output_row += "|"
print output_row
# Bottom border of row
print_bottom_border(sm.get_columns())
def print_alignments(alignment_list):
'''Prints all the alignments in the list.
The output of scoriing_algorithm.get_alignments should be fed into this.'''
i = 1
while alignment_list:
seq = alignment_list.pop()
print "Alignment #", str(i)
for s in seq:
print s
i += 1