-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathdecodonise61.m
40 lines (35 loc) · 1.2 KB
/
decodonise61.m
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
function [y] = decodonise61(x)
%DECODONISE61 - decodonises codonise61 encoded seq (e.g., 1->[1 1 1], 61->[4 4 4])
%used by RANDSEQ2 and MUTATESEQ
%
% See also: CODONISE61
% Molecular Biology and Evolution Toolbox (MBEToolbox)
% Author: James Cai
% Email: jcai@tamu.edu
% Website: http://bioinformatics.org/mbetoolbox/
%
% $LastChangedDate: 2013-01-05 12:04:29 -0600 (Sat, 05 Jan 2013) $
% $LastChangedRevision: 327 $
% $LastChangedBy: jcai $
[n,m]=size(x);
y=ones(n,m*3)*5;
[TABLE,CODON] = codontable;
icode=1;
stops=find(TABLE(icode,:)=='*');
%CODON=[1 1 1; 1 1 2; 1 1 3; 1 1 4; 1 2 1; 1 2 2; 1 2 3; 1 2 4;
% 1 3 1; 1 3 2; 1 3 3; 1 3 4; 1 4 1; 1 4 2; 1 4 3; 1 4 4;
% 2 1 1; 2 1 2; 2 1 3; 2 1 4; 2 2 1; 2 2 2; 2 2 3; 2 2 4;
% 2 3 1; 2 3 2; 2 3 3; 2 3 4; 2 4 1; 2 4 2; 2 4 3; 2 4 4;
% 3 1 1; 3 1 2; 3 1 3; 3 1 4; 3 2 1; 3 2 2; 3 2 3; 3 2 4;
% 3 3 1; 3 3 2; 3 3 3; 3 3 4; 3 4 1; 3 4 2; 3 4 3; 3 4 4;
% 4 1 1; 4 1 2; 4 1 3; 4 1 4; 4 2 1; 4 2 2; 4 2 3; 4 2 4;
% 4 3 1; 4 3 2; 4 3 3; 4 3 4; 4 4 1; 4 4 2; 4 4 3; 4 4 4];
CODON(stops,:)=[];
for (i=1:n),
for (j=1:m),
c=CODON(x(i,j),:);
y(i,(j-1)*3+1)=c(1,1);
y(i,(j-1)*3+2)=c(1,2);
y(i,(j-1)*3+3)=c(1,3);
end
end