Practical methods for constructing suffix trees

被引:40
|
作者
Tian, YY
Tata, S
Hankins, RA
Patel, JM
机构
[1] Intel Corp, Microarchitecture Res Lab, Santa Clara, CA 95054 USA
[2] Univ Michigan, Ann Arbor, MI 48109 USA
来源
VLDB JOURNAL | 2005年 / 14卷 / 03期
关键词
suffix tree construction; sequence matching;
D O I
10.1007/s00778-005-0154-8
中图分类号
TP3 [计算技术、计算机技术];
学科分类号
0812 ;
摘要
Sequence datasets are ubiquitous in modern life-science applications, and querying sequences is a common and critical operation in many of these applications. The suffix tree is a versatile data structure that can be used to evaluate a wide variety of queries on sequence datasets, including evaluating exact and approximate string matches, and finding repeat patterns. However, methods for constructing suffix trees are often very time-consuming, especially for suffix trees that are large and do not fit in the available main memory. Even when the suffix tree fits in memory, it turns out that the processor cache behavior of theoretically optimal suffix tree construction methods is poor, resulting in poor performance. Currently, there are a large number of algorithms for constructing suffix trees, but the practical tradeoffs in using these algorithms for different scenarios are not well characterized. In this paper, we explore suffix tree construction algorithms over a wide spectrum of data sources and sizes. First, we show that on modern processors, a cache-efficient algorithm with O(n(2)p) worst-case complexity outperforms popular linear time algorithms like Ukkonen and McCreight, even for in-memory construction. For larger datasets, the disk I/O requirement quickly becomes the bottleneck in each algorithm's performance. To address this problem, we describe two approaches. First, we present a buffer management strategy for the O(n(2)) algorithm. The resulting new algorithm, which we call "Top Down Disk-based" (TDD), scales to sizes much larger than have been previously described in literature. This approach far outperforms the best known disk-based construction methods. Second, we present a new disk-based suffix tree construction algorithm that is based on a sort-merge paradigm, and show that for constructing very large suffix trees with very little resources, this algorithm is more efficient than TDD.
引用
收藏
页码:281 / 299
页数:19
相关论文
共 50 条
  • [1] Practical methods for constructing suffix trees
    Yuanyuan Tian
    Sandeep Tata
    Richard A. Hankins
    Jignesh M. Patel
    [J]. The VLDB Journal, 2005, 14 : 281 - 299
  • [2] Practical Compressed Suffix Trees
    Canovas, Rodrigo
    Navarro, Gonzalo
    [J]. EXPERIMENTAL ALGORITHMS, PROCEEDINGS, 2010, 6049 : 94 - 105
  • [3] Practical Compressed Suffix Trees
    Abeliuk, Andres
    Canovas, Rodrigo
    Navarro, Gonzalo
    [J]. ALGORITHMS, 2013, 6 (02) : 319 - 351
  • [4] Constructing large suffix trees on a computational grid
    Chen, Chunxi
    Schmidt, Bertil
    [J]. JOURNAL OF PARALLEL AND DISTRIBUTED COMPUTING, 2006, 66 (12) : 1512 - 1523
  • [5] CONSTRUCTING SUFFIX TREES ON LINE IN LINEAR TIME
    UKKONEN, E
    [J]. IFIP TRANSACTIONS A-COMPUTER SCIENCE AND TECHNOLOGY, 1992, 12 : 484 - 492
  • [6] Constructing Generalized Suffix Trees on Distributed Parallel Platforms
    A. Hlybovets
    V. Didenko
    [J]. Cybernetics and Systems Analysis, 2023, 59 : 49 - 60
  • [7] Constructing suffix trees on-line in linear time
    Ukkonen, E.
    [J]. Proceedings of the IFIP World Computer Congress, 1992, 1
  • [8] Constructing Generalized Suffix Trees on Distributed Parallel Platforms
    Hlybovets, A.
    Didenko, V.
    [J]. CYBERNETICS AND SYSTEMS ANALYSIS, 2023, 59 (01) : 49 - 60
  • [9] On suffix extensions in suffix trees
    Breslauer, Dany
    Italiano, Giuseppe F.
    [J]. THEORETICAL COMPUTER SCIENCE, 2012, 457 : 27 - 34
  • [10] On Suffix Extensions in Suffix Trees
    Breslauer, Dany
    Italiano, Giuseppe F.
    [J]. STRING PROCESSING AND INFORMATION RETRIEVAL, 2011, 7024 : 301 - +