convert code into matlab code

8 views (last 30 days)
hi, i badly need this code, but it is not matlab code. this is code foe sequence local alignment(smith-waterman), I did not find it as matlab code .I converted most of this code but the last part, I did not know the commands of this programming language can anybody help to convert the following code into matlab?
  1. trace-back
my $align1 = "";
my $align2 = "";
my $j = $max_j;
my $i = $max_i;
while (1) {
last if $matrix[$i][$j]{pointer} eq "none";
if ($matrix[$i][$j]{pointer} eq "diagonal") {
$align1 .= substr($seq1, $j-1, 1);
$align2 .= substr($seq2, $i-1, 1);
$i--; $j--;
}
elsif ($matrix[$i][$j]{pointer} eq "left") {
$align1 .= substr($seq1, $j-1, 1);
$align2 .= "-";
$j--;
}
elsif ($matrix[$i][$j]{pointer} eq "up") {
$align1 .= "-";
$align2 .= substr($seq2, $i-1, 1);
$i--;
}
}
$align1 = reverse $align1;
$align2 = reverse $align2;
print "$align1\n";
print "$align2\n";
thanks in advance

Accepted Answer

Walter Roberson
Walter Roberson on 27 Dec 2011
Looks like perl.
last if condition
translates to
if condition; break; end
and
A .= B
translates to
A = [A B]
and
$matrix[$i][$j]{pointer}
translates to
matrix(i,j).pointer
and
reverse $align1
translates to
fliplr(align1)
  5 Comments
huda nawaf
huda nawaf on 29 Dec 2011
hi walter,
this code of perl is very tired:
I totally converted it of course with you help , but I found out something I forgot it so I have not correct result
I looked for in google about what mean 'next' with 'if' in perl , but did not understand it, I did not pick up what is the role of 'next' here:
if ($diagonal_score <= 0 and $up_score <= 0 and $left_score <= 0) {
$matrix[$i][$j]{score} = 0;
$matrix[$i][$j]{pointer} = "none";
next; # terminate this iteration of the loop
}
many thanks in advance
Walter Roberson
Walter Roberson on 29 Dec 2011
"next" in perl is the equivalent of "continue" -- that is, skip any further instructions in the body of the loop and start the next iteration of the loop.
This contrasts with perl's "last", which is the equivalent of "break" -- that is, skip any further instructions in the body of the loop and exit the loop itself, continuing on after the end of the loop.

Sign in to comment.

More Answers (1)

Diego
Diego on 30 Dec 2011
If you have the bioinfo toolbox, then you probably have the swalign file that implements the smith-waterman algorithm. On the other hand, I just discovered that Matlab runs perl scripts smoothly! In my case, I have a perl script that uses the bioperl module and Matlab ran it!. I said this because I was facing a similar problem, and these tips may help you to accomplish your work. Regards, Diego
  4 Comments
huda nawaf
huda nawaf on 30 Dec 2011
hi Diego,
I'm glad to hear that someone use alignment with non biological seq.
in fact, I can not use swalign and nwalign , because these codes defined just for 4 symbols (A,C,G,T) or 20 symols of amino acids. In my situation , need more symbols to represent my data, not just this reason ,but because of substitution matrices, BLOSUM AND PAM , are defined just for Nucleotides and amino acids.
In my situation , I think i have to use unitary matrix instead of BLOSUM and PAM.
currently, i try to write code of smith-waterman . Regarding Needleman I wrote it, it is work correctly.
huda nawaf
huda nawaf on 31 Dec 2011
hi,
is necessary existence perl software to run perl script in matlab?

Sign in to comment.

Tags

No tags entered yet.

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!