Generalized suffix tree

From Wikipedia, the free encyclopedia
(Redirected from Generalised suffix tree)
Jump to navigation Jump to search
Suffix tree for the strings ABAB and BABA. Suffix links not shown.

In computer science, a generalized suffix tree is a suffix tree for a set of strings. Given the set of strings D=S1,S2,,Sd of total length n, it is a Patricia tree containing all n suffixes of the strings. It is mostly used in bioinformatics.[1]

Functionality

[edit | edit source]

It can be built in Θ(n) time and space, and can be used to find all z occurrences of a string P of length m in O(m+z) time, which is asymptotically optimal (assuming the size of the alphabet is constant[2]: 119 ).

When constructing such a tree, each string should be padded with a unique out-of-alphabet marker symbol (or string) to ensure no suffix is a substring of another, guaranteeing each suffix is represented by a unique leaf node.

Algorithms for constructing a GST include Ukkonen's algorithm (1995) and McCreight's algorithm (1976).

Example

[edit | edit source]

A suffix tree for the strings ABAB and BABA is shown in a figure above. They are padded with the unique terminator strings $0 and $1. The numbers in the leaf nodes are string number and starting position. Notice how a left to right traversal of the leaf nodes corresponds to the sorted order of the suffixes. The terminators might be strings or unique single symbols. Edges on $ from the root are left out in this example.

Alternatives

[edit | edit source]

An alternative to building a generalized suffix tree is to concatenate the strings, and build a regular suffix tree or suffix array for the resulting string. When hits are evaluated after a search, global positions are mapped into documents and local positions with some algorithm and/or data structure, such as a binary search in the starting/ending positions of the documents.

References

[edit | edit source]
  1. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
  2. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
[edit | edit source]
  • Error creating thumbnail: File missing Media related to Lua error in Module:Commons_link at line 62: attempt to index field 'wikibase' (a nil value). at Wikimedia Commons
  • A C implementation of Generalized Suffix Tree for two strings