forked from xuyk/Rosalind
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path059_FULL.py
46 lines (37 loc) · 1.07 KB
/
059_FULL.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
#!/usr/bin/env python
'''
A solution to a ROSALIND bioinformatics problem.
Problem Title: Inferring Peptide from Full Spectrum
Rosalind ID: FULL
Rosalind #: 059
URL: http://rosalind.info/problems/full/
'''
from scripts import ProteinWeightDict as pw_dict
def find_weight_match(current_w, w_list):
for weight in w_list:
for item in pw_dict().items():
if abs(item[1] - (weight - current)) < 0.01:
return item[0]
return -1
if __name__ == '__main__':
with open('data/rosalind_full.txt') as input_data:
weights = [float(line.strip()) for line in input_data.readlines()]
# Given that len(weights) = 2n+3
n = (len(weights)-3)/2
# Initialize Variables
protein = ''
current = weights[1]
myw = [w for w in weights[2:]]
# Iteratively build the protein.
while len(protein) < n:
temp = find_weight_match(current, myw)
if temp == -1:
break
else:
protein += temp
current += pw_dict()[temp]
myw = filter(lambda w: w-current > 0, myw)
# Print and save the output.
print protein
with open('output/059_FULL.txt', 'w') as output_file:
output_file.write(protein)