Click here to load reader

Combinatorial Pattern Matching - Computer · PDF file 2011-04-27 · Approximate Pattern Matching: Running Time • We can generalize the “Approximate Pattern Matching Problem”

  • View
    2

  • Download
    0

Embed Size (px)

Text of Combinatorial Pattern Matching - Computer · PDF file 2011-04-27 · Approximate...

  • www.bioalgorithms.info An Introduction to Bioinformatics Algorithms

    Combinatorial 
 Pattern Matching

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Outline •  Hash Tables •  Repeat Finding •  Exact Pattern Matching •  Keyword Trees •  Suffix Trees •  Heuristic Similarity Search Algorithms •  Approximate String Matching •  Filtration •  Comparing a Sequence Against a Database •  Algorithm behind BLAST •  Statistics behind BLAST •  PatternHunter and BLAT

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Genomic Repeats •  Example of repeats:

    • ATGGTCTAGGTCCTAGTGGTC •  Motivation to find them:

    •  Genomic rearrangements are often associated with repeats

    •  Trace evolutionary secrets •  Many tumors are characterized by an

    explosion of repeats

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Genomic Repeats •  The problem is often more difficult:

    • ATGGTCTAGGACCTAGTGTTC •  Motivation to find them:

    •  Genomic rearrangements are often associated with repeats

    •  Trace evolutionary secrets •  Many tumors are characterized by an

    explosion of repeats

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    l-mer Repeats •  Long repeats are difficult to find •  Short repeats are easy to find (e.g., hashing)

    •  Simple approach to finding long repeats: •  Find exact repeats of short l-mers (l is usually

    10 to 13)

    •  Use l-mer repeats to potentially extend into longer, maximal repeats

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    l-mer Repeats (cont’d) •  There are typically many locations where an l-mer is repeated:

    GCTTACAGATTCAGTCTTACAGATGGT •  The 4-mer TTAC starts at locations 3 and 17

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Extending l-mer Repeats GCTTACAGATTCAGTCTTACAGATGGT •  Extend these 4-mer matches: GCTTACAGATTCAGTCTTACAGATGGT •  Maximal repeat: TTACAGAT

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Maximal Repeats •  To find maximal repeats in this way, we need

    ALL start locations of all l-mers in the genome

    •  Hashing lets us find repeats quickly in this manner

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Hashing: What is it? •  What does hashing do?

    •  For different data, generate a unique

    integer

    •  Store data in an array at the unique integer index generated from the data

    •  Hashing is a very efficient way to store and retrieve data

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Hashing: Definitions •  Hash table: array used in hashing •  Records: data stored in a hash table •  Keys: identifies sets of records •  Hash function: uses a key to generate an

    index to insert at in hash table

    •  Collision: when more than one record is mapped to the same index in the hash table

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Hashing: Example •  Where do the

    animals eat? •  Records: each

    animal

    •  Keys: where each animal eats

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Hashing: Finding Repeats •  To find repeats in a genome:

    •  For all l-mers in the genome, note the start position and the sequence

    •  Generate a hash table index for each unique l-mer sequence

    •  In each index of the hash table, store all genome start locations of the l-mer which generated that index

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Hashing: Collisions

    •  Dealing with collisions: •  “Chain” all start

    locations of l-mers (linked list)

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Pattern Matching •  What if, instead of finding repeats in a

    genome, we want to find all sequences in a database that contain a given pattern?

    •  This leads us to a different problem, the Pattern Matching Problem

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Pattern Matching Problem •  Goal: Find all occurrences of a pattern in a text

    •  Input: Pattern p = p1…pn and text t = t1…tm

    •  Output: All positions 1< i < (m – n + 1) such that the n-letter substring of t starting at i matches p

    •  Motivation: Searching database for a known pattern

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Exact Pattern Matching: A Brute-Force Algorithm


    PatternMatching(p,t) 1 n  length of pattern p 2 m  length of text t 3  for i  1 to (m – n + 1) 4  if ti…ti+n-1 = p 5  output i

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Exact Pattern Matching: An Example

    •  PatternMatching algorithm for:

    •  Pattern GCAT

    •  Text CGCATC

    GCAT CGCATC GCAT

    CGCATC

    CGCATC GCAT

    CGCATC

    CGCATC GCAT

    GCAT

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Exact Pattern Matching: Running Time •  PatternMatching runtime: O(nm) •  Probability-wise, it’s more like O(m)

    •  Rarely will there be close to n comparisons in line 4

    •  Better solution: suffix trees •  Can solve problem in O(m) time •  Conceptually related to keyword trees

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Multiple Pattern Matching Problem •  Goal: Given a set of patterns and a text, find all

    occurrences of any of patterns in text

    •  Input: k patterns p1,…,pk, and text t = t1…tm

    •  Output: Positions 1 < i < m where substring of t starting at i matches pj for 1 < j < k

    •  Motivation: Searching database for known multiple patterns

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Multiple Pattern Matching: Straightforward Approach •  Can solve as k “Pattern Matching Problems”

    •  Runtime: O(kmn) using the PatternMatching algorithm k times •  m - length of the text •  n - average length of the pattern

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Keyword Trees: Example •  Keyword tree:

    •  Apple

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Keyword Trees: Example (cont’d) •  Keyword tree:

    •  Apple •  Apropos

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Keyword Trees: Example (cont’d) •  Keyword tree:

    •  Apple •  Apropos •  Banana

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Keyword Trees: Example (cont’d) •  Keyword tree:

    •  Apple •  Apropos •  Banana •  Bandana

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Keyword Trees: Example (cont’d) •  Keyword tree:

    •  Apple •  Apropos •  Banana •  Bandana •  Orange

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Keyword Trees: Threading (cont’d) •  Thread “appeal”

    •  appeal

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Keyword Trees: Threading (cont’d) •  Thread “appeal”

    •  appeal

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Keyword Trees: Threading (cont’d) •  Thread “appeal”

    •  appeal

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Keyword Trees: Threading (cont’d) •  Thread “appeal”

    •  appeal

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Keyword Trees: Threading (cont’d) •  Thread “apple”

    •  apple

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Keyword Trees: Threading (cont’d) •  Thread “apple”

    •  apple

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Keyword Trees: Threading (cont’d) •  Thread “apple”

    •  apple

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.info

    Keyword Trees: Threading (cont’d) •  Thread “apple”

    •  apple

  • An Introduction to Bioinformatics Algorithms www.bioalgorithms.in

Search related