Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revisionPrevious revision
Next revision
Previous revision
Next revisionBoth sides next revision
courses:cs211:winter2011:journals:charles:chapter6 [2011/03/30 03:45] – [6.7 Sequence Alignment in Linear Space via Divide and Conquer] gouldccourses:cs211:winter2011:journals:charles:chapter6 [2011/03/30 04:41] – [6.8 Shortest Paths in a Graph] gouldc
Line 49: Line 49:
 This section shows us an improved algorithm for sequence alignment. It still runs in O(mn) time but it decreases the space requirement from O(mn) to O(m+n). We realize that computing a single column in the memoized array in the last problem only requires us to know about the current column and the previous column. Therefore it is possible to arrive at the solution while only maintaining a m-by-2 array instead of a m-by-n array. This idea will work nicely for building up to the solution //value// (i.e., the total cost of all gaps and mismatches)... but we also want to know the optimal //sequence// itself. This section shows us an improved algorithm for sequence alignment. It still runs in O(mn) time but it decreases the space requirement from O(mn) to O(m+n). We realize that computing a single column in the memoized array in the last problem only requires us to know about the current column and the previous column. Therefore it is possible to arrive at the solution while only maintaining a m-by-2 array instead of a m-by-n array. This idea will work nicely for building up to the solution //value// (i.e., the total cost of all gaps and mismatches)... but we also want to know the optimal //sequence// itself.
  
-am having a difficult time wrapping my head around the divide-and-conquer component this problem. In class we went over this graphically; we started in the top left and found the shortest path to some midpoint, then we did the same thing from the bottom right. I +We do this by incorporating divide-and-conquer principles into our algorithm. I'm slightly confused by the divide-and-conquer component to this problem. In class we did it with the graph in Figure 6.19. We started in the top left and found the shortest path to some midpoint, then we did the same thing from the bottom right. I will need to look in more depth at the pseudo-code on page 288 to get a better grasp of the concept.
 ===== 6.8 Shortest Paths in a Graph ===== ===== 6.8 Shortest Paths in a Graph =====
 +Shortest path in a directed graph where negative edges are possible. For this reason Dijkstra's Algorithm doesn't always work. (We cannot grow the blob, but we can build up partial solutions under the constraint that we can only use i edges.) In this problem we assume there are no negative cycles (cycles that decrease the total cost of the path); otherwise you could follow the cycle infinitely many times and reduce the cost to negative infinity.
 +
 +We want the path from s -> t that minimizes the total edge costs but that uses at most i edges. (6.22) says that the longest possible optimal path has n-1 edges.
 +
 +(6.23) //OPT(i,v) = min(OPT(i-1,v), min_w(OPT(i-1,w) + cw))//
courses/cs211/winter2011/journals/charles/chapter6.txt · Last modified: 2011/04/05 05:52 by gouldc
CC Attribution-Noncommercial-Share Alike 4.0 International
Driven by DokuWiki Recent changes RSS feed Valid CSS Valid XHTML 1.0