greedy algorithms

49
Greedy Algorithms CS 466 Saurabh Sinha

Upload: ehren

Post on 07-Feb-2016

88 views

Category:

Documents


1 download

DESCRIPTION

Greedy Algorithms. CS 466 Saurabh Sinha. Chapter 5.5. A greedy approach to the motif finding problem. Given t sequences of length n each, to find a profile matrix of length l . Enumerative approach O( l n t ) Impractical? - PowerPoint PPT Presentation

TRANSCRIPT

Page 1: Greedy Algorithms

Greedy Algorithms

CS 466Saurabh Sinha

Page 2: Greedy Algorithms

A greedy approach to the motif finding problem

• Given t sequences of length n each, to find a profile matrix of length l.

• Enumerative approach O(l nt) – Impractical?

• Instead consider a more practical algorithm called “GREEDYMOTIFSEARCH”

Chapter 5.5

Page 3: Greedy Algorithms

Greedy Motif Search• Find two closest l-mers in sequences 1 and 2 and form 2 x l alignment matrix with Score(s,2,DNA)

• At each of the following t-2 iterations, finds a “best” l-mer in sequence i from the perspective of the already constructed (i-1) x l alignment matrix for the first (i-1) sequences

• In other words, it finds an l-mer in sequence i maximizing Score(s,i,DNA)

under the assumption that the first (i-1) l-mers have been already chosen

• Sacrifices optimal solution for speed: in fact the bulk of the time is actually spent locating the first 2 l-mers

Page 4: Greedy Algorithms

Greedy Motif Search pseudocode• GREEDYMOTIFSEARCH (DNA, t, n, l)• bestMotif := (1,…,1)• s := (1,…,1)• for s1=1 to n-l+1

for s2 = 1 to n-l+1 if (Score(s,2,DNA) > Score(bestMotif,2,DNA) bestMotif1 := s1

bestMotif2 := s2

• s1 := bestMotif1; s2 := bestMotif2

• for i = 3 to t for si = 1 to n-l+1 if (Score(s,i,DNA) > Score(bestMotif,i,DNA) bestMotifi := si

si := bestMotifi • Return bestMotif

Page 5: Greedy Algorithms

Issues with the “score”

• Score of a profile matrix looks only at the “majority” base in each column, not at the entire distribution

• The issue of non-uniform “background” frequencies of bases in the genome

• A better “score” of a profile matrix ?

Page 6: Greedy Algorithms

Information Content• First convert a “profile matrix” to a “position weight

matrix” or PWM– Convert frequencies to probabilities

• PWM W: Wk = frequency of base at position k

• q = frequency of base by chance

• Information content of W:

Wβk logWβk

qββ ∈{A ,C ,G,T}∑

k∑

Page 7: Greedy Algorithms

Information Content

• If Wk is always equal to q, i.e., if W is similar to random sequence, information content of W is 0.

• If W is different from q, information content is high.

Page 8: Greedy Algorithms

Greedy Motif Search• Can be trivially modified to use “Information Content” as the score

• Use statistical criteria to evaluate significance of Information Content

• At each step, instead of choosing the top (1) partial motif, keep the top k partial motifs

– “Beam search”

• The program “CONSENSUS” from Stormo lab.

• Further Reading: Hertz, Hartzell & Stormo, CABIOS (1990) http://bioinf.kvl.dk/~gorodkin/teach/bioinf2004/hertz90.pdf

Page 9: Greedy Algorithms

A new problem:Genome Rearrangements

Page 10: Greedy Algorithms

Genome Rearrangements

• Most mouse genes have human orthologs (i.e., share common evolutionary ancestor)

• The order of genes in the mouse genome is not exactly the same as in human

• However, there are subsets of genes with preserved order between human-mouse (“in synteny”)

Page 11: Greedy Algorithms

Genome Rearrangements• The mouse genome can be cut into ~300 (not necessarily

equal) pieces and joined pasted together in a different order (“rearranged”) to obtain the gene order of the human genome

• Each such piece is called a “synteny block”

• Synteny blocks from different chromosomes in mouse are together on the same chromosome in human

Page 12: Greedy Algorithms

Comparative Genomic Architectures: Mouse vs Human Genome

• Humans and mice have similar genomes, but their genes are ordered differently

• ~245 rearrangements– Reversals– Fusions– Fissions– Translocation

Page 13: Greedy Algorithms

A type of rearrangement: Reversal

1 32

4

10

56

89

71, 2, 3, 4, 5, 6, 7, 8, 9, 10

Page 14: Greedy Algorithms

1 32

4

10

56

89

71, 2, 3, -8, -7, -6, -5, -4, 9, 10

A type of rearrangement: Reversal

Page 15: Greedy Algorithms

1 32

4

10

56

89

71, 2, 3, -8, -7, -6, -5, -4, 9, 10

The reversal introduced two breakpoints

Breakpoints

Page 16: Greedy Algorithms

Four types of Rearrangements

Reversal1 2 3 4 5 6 1 2 -5 -4 -3 6

Translocation1 2 3 44 5 6

1 2 6 4 5 3

1 2 3 4 5 6

1 2 3 4 5 6

Fusion

Fission

Page 17: Greedy Algorithms

Turnip vs Cabbage: Almost Identical mtDNA gene sequences

• In 1980s Jeffrey Palmer studied evolution of plant organelles by comparing mitochondrial genomes of the cabbage and turnip

• 99% similarity between genes

• These surprisingly identical gene sequences differed in gene order

• This study helped pave the way to analyzing genome rearrangements in molecular evolution

Page 18: Greedy Algorithms

Transforming Cabbage into Turnip

Page 19: Greedy Algorithms

Genome Rearrangement

• Consider reversals only.– These are most common. “… genome rearrangements

is a common mode of molecular evolution in mitochondrial, chloroplast, viral and bacterial DNA” [Hannenhalli & Pevzner 1999].

• How to transform one genome (i.e., gene ordering) to another, using the least number of reversals ?

Page 20: Greedy Algorithms

Reversals: Example = 1 2 3 4 5 6 7 8

(3,5)

1 2 5 4 3 6 7 8

Page 21: Greedy Algorithms

Reversals: Example = 1 2 3 4 5 6 7 8

(3,5)

1 2 5 4 3 6 7 8

(5,6)

1 2 5 4 6 3 7 8

Page 22: Greedy Algorithms

Reversals and Gene Orders• Gene order is represented by a permutation 1 ------ i-1 i i+1 ------ j-1 j j+1 ----- n

1 ------ i-1 j j-1 ------ i+1 i j+1 ----- n

Reversal ( i, j ) reverses (flips) the elements from i to j in

,j)

Page 23: Greedy Algorithms

Reversal Distance Problem

• Goal: Given two permutations, find the shortest series of reversals that transforms one into another

• Input: Permutations and

• Output: A series of reversals 1,…t transforming into such that t is minimum

• t - reversal distance between and

Page 24: Greedy Algorithms

Different way of stating the same problem: Sorting By Reversals

• Goal: Given a permutation, find a shortest series of reversals that transforms it into the identity permutation (1 2 … n )

• Input: Permutation

• Output: A series of reversals 1, … t transforming into the identity permutation such that t is minimum

Page 25: Greedy Algorithms

Sorting By Reversals: A Greedy Algorithm

• If sorting permutation = 1 2 3 6 4 5, the first three elements are already in order so it does not make any sense to break them.

• The length of the already sorted prefix of is denoted prefix()– prefix() = 3

• This results in an idea for a greedy algorithm: increase prefix() at every step

Page 26: Greedy Algorithms

• Doing so, can be sorted

1 2 3 6 4 5

1 2 3 4 6 5 1 2 3 4 5 6

• Number of steps to sort permutation of length n is at most (n – 1)

Greedy Algorithm: An Example

Page 27: Greedy Algorithms

Greedy Algorithm: Pseudocode

SimpleReversalSort()1 for i 1 to n – 12 j position of element i in (i.e., j = i)3 if j ≠i * (i, j)• output 6 if is the identity permutation 7 return

Page 28: Greedy Algorithms

Analyzing SimpleReversalSort

• SimpleReversalSort does not guarantee the smallest number of reversals and takes five steps on = 6 1 2 3 4 5 :

• Step 1: 1 6 2 3 4 5• Step 2: 1 2 6 3 4 5 • Step 3: 1 2 3 6 4 5• Step 4: 1 2 3 4 6 5• Step 5: 1 2 3 4 5 6

Page 29: Greedy Algorithms

• But it can be sorted in two steps: = 6 1 2 3 4 5 – Step 1: 5 4 3 2 1 6 – Step 2: 1 2 3 4 5 6

• So, SimpleReversalSort() is not optimal

• Optimal algorithms are unknown for many problems; approximation algorithms are used

Analyzing SimpleReversalSort (cont’d)

Page 30: Greedy Algorithms

Approximation Algorithms• These algorithms find approximate solutions

rather than optimal solutions• The approximation ratio of an algorithm A on

input is: A() / OPT()where A() -solution produced by algorithm A

OPT() - optimal solution of the problem

Page 31: Greedy Algorithms

Approximation Ratio/Performance Guarantee

• Approximation ratio (performance guarantee) of algorithm A: max approximation ratio of all inputs of size n

• For algorithm A that minimizes objective function (minimization algorithm):

• max|| = n A() / OPT()

• For maximization algorithm:• min|| = n A() / OPT(

Page 32: Greedy Algorithms

= 23…n-1n

• A pair of elements i and i + 1 are adjacent if

i+1 = i + 1• For example: = 1 9 3 4 7 8 2 6 5• (3, 4) or (7, 8) and (6,5) are adjacent pairs

Adjacencies and Breakpoints

Page 33: Greedy Algorithms

There is a breakpoint between any pair of adjacent elements that are non-consecutive:

= 1 9 3 4 7 8 2 6 5

• Pairs (1,9), (9,3), (4,7), (8,2) and (2,6) form breakpoints of permutation

• b() - # breakpoints in permutation

Breakpoints: An Example

Page 34: Greedy Algorithms

Adjacency & Breakpoints•An adjacency - a pair of adjacent elements that are consecutive

• A breakpoint - a pair of adjacent elements that are not consecutive

π = 5 6 2 1 3 4

0 5 6 2 1 3 4 7adjacencies

breakpoints

Extend π with π0 = 0 and π7 = 7

Page 35: Greedy Algorithms

Each reversal eliminates at most 2 breakpoints.

= 2 3 1 4 6 50 2 3 1 4 6 5 7 b() = 50 1 3 2 4 6 5 7 b() = 40 1 2 3 4 6 5 7 b() = 20 1 2 3 4 5 6 7 b() = 0

Reversal Distance and Breakpoints

Page 36: Greedy Algorithms

Each reversal eliminates at most 2 breakpoints.

= 2 3 1 4 6 50 2 3 1 4 6 5 7 b() = 50 1 3 2 4 6 5 7 b() = 40 1 2 3 4 6 5 7 b() = 20 1 2 3 4 5 6 7 b() = 0

Reversal Distance and Breakpoints

reversal distance ≥ #breakpoints / 2

Page 37: Greedy Algorithms

Sorting By Reversals: A different greedy algorithm

BreakPointReversalSort()1 while b() > 0• Among all possible reversals,

choose reversal minimizing b( • )3 • (i, j)4 output 5 return

Page 38: Greedy Algorithms

Thoughts on BreakPointReversalsSort

• A “different face of greed”: breakpoints as the marker of progress

• Why is this algorithm better than SimpleReversalSort ? Don’t know how many steps it may take

• Does this algorithm even terminate ?

• We need some analysis …

Page 39: Greedy Algorithms

Strips• Strip: an interval between two consecutive

breakpoints in a permutation – Decreasing strip: strip of elements in decreasing

order– Increasing strip: strip of elements in increasing order 0 1 9 4 3 7 8 2 5 6 10

– A single-element strip can be declared either increasing or decreasing. We will choose to declare them as decreasing with exception of the strips with 0 and n+1

Page 40: Greedy Algorithms

Reducing the Number of Breakpoints

Theorem 1: If permutation contains at least one

decreasing strip, then there exists a reversal which decreases the number of breakpoints (i.e. b( • ) < b() )

Page 41: Greedy Algorithms

Things To Consider• For = 1 4 6 5 7 8 3 2 0 1 4 6 5 7 8 3 2 9 b() = 5

– Choose decreasing strip with the smallest element k in ( k = 2 in this case)

Page 42: Greedy Algorithms

• For = 1 4 6 5 7 8 3 2 0 1 4 6 5 7 8 3 22 9 b() = 5

– Choose decreasing strip with the smallest element k in ( k = 2 in this case)

Things To Consider

Page 43: Greedy Algorithms

• For = 1 4 6 5 7 8 3 2 0 11 4 6 5 7 8 3 22 9 b() = 5

– Choose decreasing strip with the smallest element k in ( k = 2 in this case)

– Find k – 1 in the permutation

Things To Consider

Page 44: Greedy Algorithms

• For = 1 4 6 5 7 8 3 2 0 1 4 6 5 7 8 3 2 9 b() = 5

– Choose decreasing strip with the smallest element k in ( k = 2 in this case)

– Find k – 1 in the permutation– Reverse the segment between k and k-1:– 0 1 4 6 5 7 8 3 2 9 b() = 5

– 0 1 2 3 8 7 5 6 4 9 b() = 4

Things To Consider

Page 45: Greedy Algorithms

Reducing the Number of Breakpoints (Again)

– If there is no decreasing strip, there may be no reversal that reduces the number of breakpoints (i.e. b( • ) ≥ b() for any reversal ).

– By reversing an increasing strip ( # of breakpoints stay unchanged ), we will create a decreasing strip at the next step. Then the number of breakpoints will be reduced in the next step (theorem 1).

Page 46: Greedy Algorithms

ImprovedBreakpointReversalSortImprovedBreakpointReversalSort()1 while b() > 02 if has a decreasing strip• Among all possible reversals, choose reversal that minimizes b( • )4 else5 Choose a reversal that flips an increasing

strip in 6 • 7 output 8 return

Page 47: Greedy Algorithms

• ImprovedBreakPointReversalSort is an approximation algorithm with a performance guarantee of at most 4– It eliminates at least one breakpoint in every two

steps; at most 2b() steps– Approximation ratio: 2b() / d()– Optimal algorithm eliminates at most 2

breakpoints in every step: d() b() / 2– Performance guarantee:

•( 2b() / d() ) [ 2b() / (b() / 2) ] = 4

ImprovedBreakpointReversalSort: Performance Guarantee

Page 48: Greedy Algorithms

Classic result

• There exists a polynomial time algorithm to compute the “reversal distance” of two “signed” permutations (genes have orientations, + or -).

• Due to Hannenhalli & Pevzner. See http://www.akira.ruc.dk/~keld/teaching/algoritmedesign_f08/Artikler/04/Bergeron01.pdf

Page 49: Greedy Algorithms

Today’s summary

• Greedy algorithms• Application: motif finding problem; may

not find optimal solution• Genome Rearrangements• Greedy algorithm for Genome

Rearrangements (sorting by reversals)• Approximation algorithms