- #1
Roo2
- 47
- 0
Homework Statement
I'm having trouble understanding dynamic programming as it relates to sequence alignments. I understand from my lecture notes that the scoring matrix used has arbitrary values (in our case +5 for match, -2 for mismatch, and -6 for gap). I therefore understand why square (1,1) in our lecture notes is assigned a score of +5. However, beyond that I have no idea where the numbers in the scoring matrix came from, how to calculate them, etc. I also don't understand how the algorithm knows whether, in a case of non-matching sequence, to assign a mismatch or gap without first seeing the rest of the sequence. I'd really appreciate it if someone could help me figure this out.
Homework Equations
Lecture notes:
http://i3.photobucket.com/albums/y76/Danja91/Dynamic Programming/dynamicprogramming002.jpg
http://i3.photobucket.com/albums/y76/Danja91/Dynamic Programming/dynamicprogramming001.jpg
Web site which seems to explain the rules, but I still don't understand them:
http://www.ibm.com/developerworks/java/library/j-seqalign/index.html
The Attempt at a Solution
None, really. I found the web site, but I still don't get where the numbers are coming from. I kind of got the following:
When assigning a score to a square, it is the maximum of the three squares above, to the left, and diagonal-above-left to the square in question. Left takes priority over above, and above takes priority over diagonal.
I have no idea what the following line means (from the web site)
"
You fill in the empty cell with the maximum of these three numbers:
V1
V2
V3 + 1 if C1 equals C2, or V3 if C1 is not equal to C2, where C1 is the character above the current cell and C2 is the character to the left of the current cell"
Conceptually I get it, but I don't see how it applies to the matrix presented in my lecture notes.
Once again, I would appreciate any help. I haven't been this lost in a while.