Permuted Longest-Common-Prefix Array
|
|
- Blaze Dawson
- 6 years ago
- Views:
Transcription
1 Permuted Longest-Common-Prefix Array Juha Kärkkäinen University of Helsinki Joint work with Giovanni Manzini and Simon Puglisi CPM 2009 Lille, France, June 2009 CPM 2009 p. 1
2 Outline 1. Background 2. Description 3. Construction 4. Compact Representation CPM 2009 p. 2
3 Suffix Array and LCP Array Suffix array (SA) Powerful text index Linear time construction Longest-common-prefix (LCP) array Often used with suffix array Linear time construction from SA [Kasai & al., CPM 2001] Text + SA LCP CPM 2009 p. 3
4 Constructing SA and LCP SA 5 6n bytes, fastest in practice 2n bytes, output to disk sequentially external memory LCP array from SA 13n bytes, fastest [Kasai & al., CPM 2001] 9n bytes [Mäkinen, F. Inform. 2003] 9n or 6 10n bytes [Manzini, SWAT 2004] 2n bytes [Puglisi & Turpin, ISAAC 2008] semi-external: sequentially accessed arrays on disk CPM 2009 p. 4
5 Permuted LCP (PLCP) Array LCP array in permuted order LCP construction (or simulation) via PLCP Text + SA PLCP or Compact Representation LCP LCP Simulation Faster and more space-efficient CPM 2009 p. 5
6 Constructing LCP from SA Best previous algorithms 13n bytes, fast [Kasai & al., CPM 2001] 2n bytes, semi-external [Puglisi & Turpin, ISAAC 2008] New algorithms via PLCP semi-external 5n bytes, O(n) time, faster 11n bits, O(n log n) time (1 + 4/q)n bytes, O(nq) time CPM 2009 p. 6
7 Outline 1. Background 2. Description 3. Construction 4. Compact Representation CPM 2009 p. 7
8 Suffix Array (SA) Sorted array of all suffixes Pos. order 0 BANANA# 1 ANANA# 2 NANA# 3 ANA# 4 NA# 5 A# 6 # T = BANANA# 6 # 5 A# 3 ANA# 1 ANANA# 0 BANANA# 4 NA# 2 NANA# Lex. order Position Suffix array CPM 2009 p. 8
9 LCP Array Length of longest common prefix with preceding suffix Pos. order 0 BANANA# 1 ANANA# 2 NANA# 3 ANA# 4 NA# 5 A# 6 # T = BANANA# Lex. order - 6 # 0 5 A# 1 3 ANA# 3 1 ANANA# 0 0 BANANA# 0 4 NA# 2 2 NANA# LCP array SA CPM 2009 p. 9
10 PLCP Array LCP array permuted into the position order Pos. order 0 0 BANANA# 3 1 ANANA# 2 2 NANA# 1 3 ANA# 0 4 NA# 0 5 A# - 6 # T = BANANA# Lex. order - 6 # 0 5 A# 1 3 ANA# 3 1 ANANA# 0 0 BANANA# 0 4 NA# 2 2 NANA# PLCP LCP CPM 2009 p. 10
11 PLCP Array Structure Theorem. PLCP[i] PLCP[i 1] Used in all efficient LCP-from-SA algorithms Enables compact representation CPM 2009 p. 11
12 Outline 1. Background 2. Description 3. Construction Irreducible LCP Algorithm Φ Algorithm 4. Compact Representation CPM 2009 p. 12
13 PLCP Algorithms Text + SA PLCP or Compact Representation LCP LCP Simulation Irreducible LCP Algorithm Φ Algorithm LCP[i] = PLCP[SA[i]] CPM 2009 p. 13
14 Irreducible LCP Values LCP[i] is irreducible BWT[i] BWT[i 1] Pos. order 0 0 BANANA# 3 1 ANANA# 2 2 NANA# 1 3 ANA# 0 4 NA# 0 5 A# - 6 # T = BANANA# PLCP LCP BWT Lex. order - A 6 # 0 N 5 A# 1 N 3 ANA# 3 B 1 ANANA# 0 # 0 BANANA# 0 A 4 NA# 2 A 2 NANA# CPM 2009 p. 14
15 Irreducible LCP Values Theorem. The sum of irreducible LCP values is 2n log n Lemma. For reducible LCP value, [Manzini, SWAT 2004] PLCP[i] = PLCP[i 1] 1 CPM 2009 p. 15
16 Irreducible LCP Algorithm 1. Compute all irreducible PLCP values naively 2. Compute reducible PLCP values: PLCP[i] := PLCP[i 1] 1 3. Compute LCP from PLCP O(n log n) time Faster than previous algorithms 5n bytes semi-external = 10% slower CPM 2009 p. 16
17 Φ Algorithm 1. Compute Φ: for i := 1 to n do Φ[SA[i]] := SA[i 1] 2. Compute PLCP: l := 0 for i := 0 to n 1 do while T[i + l] = T[Φ[i] + l] do ++l PLCP[i] := l; l := max(l 1, 0) 3. Compute LCP: for i := 1 to n do LCP[i] := PLCP[SA[i]] Over 30% faster than any previous algorithm Only one random access in each round of main loop 5n bytes semi-external = 10% slower CPM 2009 p. 17
18 Time for Manzini Corpus (708 MiB) LCP PLCP Time (s) Kasai et al. Irreducible Φ CPM 2009 p. 18
19 Outline 1. Background 2. Description 3. Construction 4. Compact Representation Succinct Bitvector Sparse PLCP Array CPM 2009 p. 19
20 Succinct Bitvector Representation PLCP stored in bitvector B of 2n bits [Sadakane, SODA 2002] B = Irreducible LCP Algorithm O(n log n) time 11n bits (semi-external) CPM 2009 p. 20
21 Sparse PLCP array Store every qth entry of PLCP array Φ Algorithm O(qn) time (1 + 4/q)n bytes (semi-external) CPM 2009 p. 21
22 Space and Time for Manzini Corpus (708 MiB) 1 Bitvector 0.8 Time (s/mib) Puglisi & Turpin Sparse SA Irreducible Φ Kasai et al Space (bits/symbol), semi-external CPM 2009 p. 22
23 Conclusion Summary Faster and more space-efficient algorithms for (P)LCP array construction Irreducible LCP Theorem Open problem External memory algorithm for LCP-from-SA construction CPM 2009 p. 23
24 Dmitry Khmelev Died at young age in 2004 Mathematician doing stringology as hobby Conjectured the Irreducible LCP Theorem LCP construction algorithm Implementation, no publication Uses sparse PLCP array Analysis relies on Irreducible LCP Theorem CPM 2009 p. 24
arxiv: v3 [cs.ds] 29 Jun 2010
Sampled Longest Common Prefix Array Jouni Sirén Department of Computer Science, University of Helsinki, Finland jltsiren@cs.helsinki.fi arxiv:1001.2101v3 [cs.ds] 29 Jun 2010 Abstract. When augmented with
More informationarxiv: v1 [cs.ds] 20 Dec 2010
Lightweight LCP-Array Construction in Linear Time Simon Gog and Enno Ohlebusch Institute of Theoretical Computer Science, University of Ulm, D-89069 Ulm Simon.Gog@uni-ulm.de, Enno.Ohlebusch@uni-ulm.de
More informationDistributed Suffix Array Construction
Distributed Suffix Array Construction Huibin Shen Department of Computer Science University of Helsinki String Processing Project April 25, 2012 Huibin Shen (U.H.) Distributed Suffix Array Construction
More informationSuffix Array Construction
Suffix Array Construction Suffix array construction means simply sorting the set of all suffixes. Using standard sorting or string sorting the time complexity is Ω(DP (T [0..n] )). Another possibility
More informationBurrows Wheeler Transform
Burrows Wheeler Transform The Burrows Wheeler transform (BWT) is an important technique for text compression, text indexing, and their combination compressed text indexing. Let T [0..n] be the text with
More informationApplications of Suffix Tree
Applications of Suffix Tree Let us have a glimpse of the numerous applications of suffix trees. Exact String Matching As already mentioned earlier, given the suffix tree of the text, all occ occurrences
More informationLinear-Time Suffix Array Implementation in Haskell
Linear-Time Suffix Array Implementation in Haskell Anna Geiduschek and Ben Isaacs CS240H Final Project GitHub: https://github.com/ageiduschek/dc3 Suffix Array June 5th, 2014 Abstract The purpose of our
More informationLCP Array Construction
LCP Array Construction The LCP array is easy to compute in linear time using the suffix array SA and its inverse SA 1. The idea is to compute the lcp values by comparing the suffixes, but skip a prefix
More informationLecture 7 February 26, 2010
6.85: Advanced Data Structures Spring Prof. Andre Schulz Lecture 7 February 6, Scribe: Mark Chen Overview In this lecture, we consider the string matching problem - finding all places in a text where some
More informationEngineering a Lightweight External Memory Su x Array Construction Algorithm
Engineering a Lightweight External Memory Su x Array Construction Algorithm Juha Kärkkäinen, Dominik Kempa Department of Computer Science, University of Helsinki, Finland {Juha.Karkkainen Dominik.Kempa}@cs.helsinki.fi
More informationLecture 18 April 12, 2005
6.897: Advanced Data Structures Spring 5 Prof. Erik Demaine Lecture 8 April, 5 Scribe: Igor Ganichev Overview In this lecture we are starting a sequence of lectures about string data structures. Today
More informationLempel-Ziv Compressed Full-Text Self-Indexes
Lempel-Ziv Compressed Full-Text Self-Indexes Diego G. Arroyuelo Billiardi Ph.D. Student, Departamento de Ciencias de la Computación Universidad de Chile darroyue@dcc.uchile.cl Advisor: Gonzalo Navarro
More informationSuffix links are stored for compact trie nodes only, but we can define and compute them for any position represented by a pair (u, d):
Suffix links are the same as Aho Corasick failure links but Lemma 4.4 ensures that depth(slink(u)) = depth(u) 1. This is not the case for an arbitrary trie or a compact trie. Suffix links are stored for
More informationLecture L16 April 19, 2012
6.851: Advanced Data Structures Spring 2012 Prof. Erik Demaine Lecture L16 April 19, 2012 1 Overview In this lecture, we consider the string matching problem - finding some or all places in a text where
More informationarxiv: v1 [cs.ds] 12 Dec 2012
Linear Time Lempel-Ziv Factorization: Simple, Fast, Small Juha Kärkkäinen, Dominik Kempa, and Simon J. Puglisi Department of Computer Science, University of Helsinki Helsinki, Finland firstname.lastname@cs.helsinki.fi
More informationFaster Average Case Low Memory Semi-External Construction of the Burrows-Wheeler Transform
Faster Average Case Low Memory Semi-External Construction of the Burrows-Wheeler German Tischler The Wellcome Trust Sanger Institute, Wellcome Trust Genome Campus Hinxton, Cambridge, CB10 1SA, United Kingdom
More informationCompressed Full-Text Indexes for Highly Repetitive Collections. Lectio praecursoria Jouni Sirén
Compressed Full-Text Indexes for Highly Repetitive Collections Lectio praecursoria Jouni Sirén 29.6.2012 ALGORITHM Grossi, Vitter: Compressed suffix arrays and suffix trees with Navarro, Mäkinen: Compressed
More informationDocument Retrieval on Repetitive Collections
Document Retrieval on Repetitive Collections Gonzalo Navarro 1, Simon J. Puglisi 2, and Jouni Sirén 1 1 Center for Biotechnology and Bioengineering, Department of Computer Science, University of Chile,
More informationExperimenting with Burrows-Wheeler Compression
Experimenting with Burrows-Wheeler Compression Juha Kärkkäinen University of Helsinki (Work done mostly as Visiting Scientist at Google Zürich) 3rd Workshop on Compression, Text and Algorithms Melbourne,
More informationParallel Lightweight Wavelet Tree, Suffix Array and FM-Index Construction
Parallel Lightweight Wavelet Tree, Suffix Array and FM-Index Construction Julian Labeit Julian Shun Guy E. Blelloch Karlsruhe Institute of Technology UC Berkeley Carnegie Mellon University julianlabeit@gmail.com
More informationAn Efficient, Versatile Approach to Suffix Sorting
An Efficient, Versatile Approach to Suffix Sorting 1.2 1.2 MICHAEL A. MANISCALCO Independent Researcher and SIMON J. PUGLISI Curtin University of Technology Sorting the suffixes of a string into lexicographical
More informationA Compressed Suffix Tree Based Implementation With Low Peak Memory Usage 1
Available online at www.sciencedirect.com Electronic Notes in Theoretical Computer Science 302 (2014) 73 94 www.elsevier.com/locate/entcs A Compressed Suffix Tree Based Implementation With Low Peak Memory
More informationLinear Work Suffix Array Construction
Linear Work Suffix Array Construction Juha Karkkainen, Peter Sanders, Stefan Burkhardt Presented by Roshni Sahoo March 7, 2019 Presented by Roshni Sahoo Linear Work Suffix Array Construction March 7, 2019
More informationA Tale of Three Algorithms: Linear Time Suffix Array Construction
A Tale of Three Algorithms: Linear Time Suffix Array Construction Juha Kärkkäinen Department of Computer Science University of Helsinki 10 August, 2006 5th Estonian Summer School in Computer and Systems
More informationEngineering a Compressed Suffix Tree Implementation
Engineering a Compressed Suffix Tree Implementation Niko Välimäki 1, Wolfgang Gerlach 2, Kashyap Dixit 3, and Veli Mäkinen 1 1 Department of Computer Science, University of Helsinki, Finland. {nvalimak,vmakinen}@cs.helsinki.fi
More informationSpace-efficient Algorithms for Document Retrieval
Space-efficient Algorithms for Document Retrieval Niko Välimäki and Veli Mäkinen Department of Computer Science, University of Helsinki, Finland. {nvalimak,vmakinen}@cs.helsinki.fi Abstract. We study the
More informationScalable and Versatile k-mer Indexing for High-Throughput Sequencing Data
Scalable and Versatile k-mer Indexing for High-Throughput Sequencing Data Niko Välimäki Genome-Scale Biology Research Program, and Department of Medical Genetics, Faculty of Medicine, University of Helsinki,
More informationCompressed Indexes for Dynamic Text Collections
Compressed Indexes for Dynamic Text Collections HO-LEUNG CHAN University of Hong Kong and WING-KAI HON National Tsing Hua University and TAK-WAH LAM University of Hong Kong and KUNIHIKO SADAKANE Kyushu
More informationString Matching. Pedro Ribeiro 2016/2017 DCC/FCUP. Pedro Ribeiro (DCC/FCUP) String Matching 2016/ / 42
String Matching Pedro Ribeiro DCC/FCUP 2016/2017 Pedro Ribeiro (DCC/FCUP) String Matching 2016/2017 1 / 42 On this lecture The String Matching Problem Naive Algorithm Deterministic Finite Automata Knuth-Morris-Pratt
More informationExternal memory BWT and LCP computation for sequence collections with applications
External memory BWT and LCP computation for sequence collections with applications Lavinia Egidi 1 University of Eastern Piedmont, Alessandria, Italy lavinia.egidi@uniupo.it https://orcid.org/0000-0002-9745-0942
More informationSolution to Problem 1 of HW 2. Finding the L1 and L2 edges of the graph used in the UD problem, using a suffix array instead of a suffix tree.
Solution to Problem 1 of HW 2. Finding the L1 and L2 edges of the graph used in the UD problem, using a suffix array instead of a suffix tree. The basic approach is the same as when using a suffix tree,
More informationRelative Suffix Trees
Relative Suffix Trees Andrea Farruggia 1, Travis Gagie 2,3, Gonzalo Navarro 2,4, Simon J. Puglisi 5 and Jouni Sirén 6 arxiv:1508.02550v3 [cs.ds] 15 Dec 2017 1. INTRODUCTION 1 Department of Computer Science,
More informationA Linear-Time Burrows-Wheeler Transform Using Induced Sorting
A Linear-Time Burrows-Wheeler Transform Using Induced Sorting Daisuke Okanohara 1 and Kunihiko Sadakane 2 1 Department of Computer Science, University of Tokyo, Hongo 7-3-1, Bunkyo-ku, Tokyo 113-0013,
More informationParallel Suffix Arrays for Linguistic Pattern Search
Parallel Suffix Arrays for Linguistic Pattern Search Johannes Goller Macmillan, Digital Science Chiyoda Bldg., 2-37 Ichigayatamachi Shinjuku-ku, Tokyo jogojapan@gmail.com Abstract The paper presents the
More informationFast Optimal Algorithms for Computing All the Repeats in a String
Outline Fast Optimal Algorithms for Computing All the Repeats in a String Simon J. Puglisi 1, W. F. Smyth 2,3 and Munina Yusufu 2 1 School of Computer Science & Information Technology RMIT University,
More informationSuffix Arrays Slides by Carl Kingsford
Suffix Arrays 02-714 Slides by Carl Kingsford Suffix Arrays Even though Suffix Trees are O(n) space, the constant hidden by the big-oh notation is somewhat big : 20 bytes / character in good implementations.
More informationComputing Longest Previous Factor in linear time and applications
Computing Longest Previous Factor in linear time and applications Maxime Crochemore, Lucian Ilie To cite this version: Maxime Crochemore, Lucian Ilie. Computing Longest Previous Factor in linear time and
More informationApplications of Succinct Dynamic Compact Tries to Some String Problems
Applications of Succinct Dynamic Compact Tries to Some String Problems Takuya Takagi 1, Takashi Uemura 2, Shunsuke Inenaga 3, Kunihiko Sadakane 4, and Hiroki Arimura 1 1 IST & School of Engineering, Hokkaido
More informationarxiv: v2 [cs.ds] 31 Aug 2012
Algorithmica manuscript No. (will be inserted by the editor) Faster Approximate Pattern Matching in Compressed Repetitive Texts Travis Gagie Pawe l Gawrychowski Christopher Hoobin Simon J. Puglisi the
More informationAn Improved Query Time for Succinct Dynamic Dictionary Matching
An Improved Query Time for Succinct Dynamic Dictionary Matching Guy Feigenblat 12 Ely Porat 1 Ariel Shiftan 1 1 Bar-Ilan University 2 IBM Research Haifa labs Agenda An Improved Query Time for Succinct
More informationEfficient compression of large repetitive strings
Efficient compression of large repetitive strings A thesis submitted in fulfillment of the requirements for the degree of Doctor of Philosophy Christopher Hoobin B.Eng (Hons.), B.App.Sci (Hons.), School
More informationDistributed String Mining for High-Throughput Sequencing Data. Department of Computer Science University of Helsinki
Distributed String Mining for High-Throughput Sequencing Data Niko Välimäki Simon J. Puglisi Department of Computer Science University of Helsinki nvalimak@cs.helsinki.fi String Mining T + = { T = { I
More informationSuffix Array Construction
7 Suffix Array Construction 7.1 Notation and terminology... 7-1 7.2 The suffix array... 7-2 7.3 The substring-search problem... 7-3 7.4 Suffix Array Construction Algorithms... 7-5 The Skew Algorithm The
More informationarxiv: v1 [cs.ds] 3 Nov 2015
Burrows-Wheeler transform for terabases arxiv:.88v [cs.ds] 3 Nov Jouni Sirén Wellcome Trust Sanger Institute Wellcome Trust Genome ampus Hinxton, ambridge, B S, UK jouni.siren@iki.fi bstract In order to
More informationI519 Introduction to Bioinformatics. Indexing techniques. Yuzhen Ye School of Informatics & Computing, IUB
I519 Introduction to Bioinformatics Indexing techniques Yuzhen Ye (yye@indiana.edu) School of Informatics & Computing, IUB Contents We have seen indexing technique used in BLAST Applications that rely
More informationParameterized Suffix Arrays for Binary Strings
Parameterized Suffix Arrays for Binary Strings Satoshi Deguchi 1, Fumihito Higashijima 1, Hideo Bannai 1, Shunsuke Inenaga 2, and Masayuki Takeda 1 1 Department of Informatics, Kyushu University 2 Graduate
More informationComputing the Longest Common Substring with One Mismatch 1
ISSN 0032-9460, Problems of Information Transmission, 2011, Vol. 47, No. 1, pp. 1??. c Pleiades Publishing, Inc., 2011. Original Russian Text c M.A. Babenko, T.A. Starikovskaya, 2011, published in Problemy
More informationImproved and Extended Locating Functionality on Compressed Suffix Arrays
Improved and Extended Locating Functionality on Compressed Suffix Arrays Simon Gog and Gonzalo Navarro 2 Department of Computing and Information Systems, The University of Melbourne. simon.gog@unimelb.edu.au
More informationEfficient repeat finding in sets of strings via suffix arrays
Discrete Mathematics and Theoretical Computer Science DMTCS vol. 15:2, 2013, 59 70 Efficient repeat finding in sets of strings via suffix arrays Pablo Barenbaum 1 Verónica Becher 1,2 Alejandro Deymonnaz
More informationSpace-efficient representations of non-linear objects
Space-efficient representations of non-linear objects Rajeev Raman, University of Leicester ラアジブラアマン レスタ大學 1 Introduction We are increasingly processing very large data sets. Processing is often complex
More informationGeneralized enhanced suffix array construction in external memory
Universidade de São Paulo Biblioteca Digital da Produção Intelectual - BDPI Outros departamentos - FFCLRP/Outros Artigos e Materiais de Revistas Científicas - ICMC/SCC 217 Generalized enhanced suffix array
More informationA simple algorithm for computing the Lempel Ziv factorization
Data Compression Conference A simple algorithm for computing the Lempel Ziv factorization Maxime Crochemore,, Lucian Ilie,, 4, 5, W. F. Smyth Department of Computer Science, King s College London, London
More informationT U M I N S T I T U T F Ü R I N F O R M A T I K. Computing Suffix Links for Suffix Trees and Arrays. Moritz G. Maaß
T U M I N S T I T U T F Ü R I N F O R M A T I K Computing Suffix Links for Suffix Trees and Arrays Moritz G. Maaß ÀÁÂ ÃÄÅÆÇ TUM-I0514 Juli 05 T E C H N I S C H E U N I V E R S I T Ä T M Ü N C H E N TUM-INFO-07-I0514-0/1.-FI
More information1 Introduciton. 2 Tries /651: Algorithms CMU, Spring Lecturer: Danny Sleator
15-451/651: Algorithms CMU, Spring 2015 Lecture #25: Suffix Trees April 22, 2015 (Earth Day) Lecturer: Danny Sleator Outline: Suffix Trees definition properties (i.e. O(n) space) applications Suffix Arrays
More informationsplitmem: graphical pan-genome analysis with suffix skips Shoshana Marcus May 7, 2014
splitmem: graphical pan-genome analysis with suffix skips Shoshana Marcus May 7, 2014 Outline 1 Overview 2 Data Structures 3 splitmem Algorithm 4 Pan-genome Analysis Objective Input! Output! A B C D Several
More informationImproved and Extended Locating Functionality on Compressed Suffix Arrays
Improved and Extended Locating Functionality on Compressed Suffix Arrays Simon Gog a, Gonzalo Navarro b, Matthias Petri c a Institute of Theoretical Informatics, Karlsruhe Institute of Technology, Germany
More informationCompressed Data Structures with Relevance
Compressed Data Structures with Relevance Jeff Vitter Provost and Executive Vice Chancellor The University of Kansas, USA (and collaborators Rahul Shah, Wing-Kai Hon, Roberto Grossi, Oğuzhan Külekci, Bojian
More informationSpace-efficient Construction of LZ-index
Space-efficient Construction of LZ-index Diego Arroyuelo and Gonzalo Navarro Dept. of Computer Science, University of Chile, Blanco Encalada 212, Santiago, Chile. {darroyue,gnavarro}@dcc.uchile.cl Abstract.
More informationBlock Graphs in Practice
Travis Gagie 1,, Christopher Hoobin 2 Simon J. Puglisi 1 1 Department of Computer Science, University of Helsinki, Finland 2 School of CSIT, RMIT University, Australia Travis.Gagie@cs.helsinki.fi Abstract
More informationNext generation sequencing: assembly by mapping reads. Laurent Falquet, Vital-IT Helsinki, June 3, 2010
Next generation sequencing: assembly by mapping reads Laurent Falquet, Vital-IT Helsinki, June 3, 2010 Overview What is assembly by mapping? Methods BWT File formats Tools Issues Visualization Discussion
More informationLightweight Data Indexing and Compression in External Memory
Lightweight Data Indexing and Compression in External Memory Paolo Ferragina 1, Travis Gagie 2, and Giovanni Manzini 3 1 Dipartimento di Informatica, Università di Pisa, Italy 2 Departamento de Ciencias
More informationInducing Suffix and LCP Arrays in External Memory
Inducing Suffix and LCP Arrays in External Memory Timo Bingmann, Johannes Fischer, and Vitaly Osipov KIT, Institute of Theoretical Informatics, 76131 Karlsruhe, Germany {timo.bingmann,johannes.fischer,osipov}@kit.edu
More informationarxiv: v1 [cs.ds] 15 Nov 2018
Vectorized Character Counting for Faster Pattern Matching Roman Snytsar Microsoft Corp., One Microsoft Way, Redmond WA 98052, USA Roman.Snytsar@microsoft.com Keywords: Parallel Processing, Vectorization,
More informationmarc skodborg, simon fischer,
E F F I C I E N T I M P L E M E N TAT I O N S O F S U F - F I X T R E E S marc skodborg, 201206073 simon fischer, 201206049 master s thesis June 2017 Advisor: Christian Nørgaard Storm Pedersen AARHUS AU
More informationEncoding Data Structures
Encoding Data Structures Rajeev Raman University of Leicester ERATO-ALSIP special seminar RMQ problem Given a static array A[1..n], pre-process A to answer queries: RMQ(l, r) : return max l i r A[i]. 47
More informationAntisequential Suffix Sorting for BWT-Based Data Compression
IEEE TRANSACTIONS ON COMPUTERS, VOL. 54, NO. 4, APRIL 2005 1 Antisequential Suffix Sorting for BWT-Based Data Compression Dror Baron, Member, IEEE, and Yoram Bresler, Fellow, IEEE Abstract Suffix sorting
More informationUC Davis UC Davis Previously Published Works
UC Davis UC Davis Previously Published Works Title Fast Parallel Suffix Array on the GPU Permalink https://escholarship.org/uc/item/83r7w305 Authors Wang, Leyuan Baxter, Sean Owens, John D. Publication
More informationBetter External Memory Suffix Array Construction
Better External Memory Suffix Array Construction ROMAN DEMENTIEV Universität Karlsruhe JUHA KÄRKKÄINEN University of Helsinki JENS MEHNERT Max-Planck-Institut für Informatik and PETER SANDERS Universität
More informationColored Range Queries and Document Retrieval 1
Colored Range Queries and Document Retrieval 1 Travis Gagie a, Juha Kärkkäinen b, Gonzalo Navarro c, Simon J. Puglisi d a Department of Computer Science and Engineering,Aalto University, Finland. b Department
More information4. Suffix Trees and Arrays
4. Suffix Trees and Arrays Let T = T [0..n) be the text. For i [0..n], let T i denote the suffix T [i..n). Furthermore, for any subset C [0..n], we write T C = {T i i C}. In particular, T [0..n] is the
More informationOptimized Succinct Data Structures for Massive Data
SOFTWARE PRACTICE AND EXPERIENCE Softw. Pract. Exper. 0000; 00:1 28 Published online in Wiley InterScience (www.interscience.wiley.com). Optimized Succinct Data Structures for Massive Data Simon Gog 1
More informationLinearized Suffix Tree: an Efficient Index Data Structure with the Capabilities of Suffix Trees and Suffix Arrays
Algorithmica (2008) 52: 350 377 DOI 10.1007/s00453-007-9061-2 Linearized Suffix Tree: an Efficient Index Data Structure with the Capabilities of Suffix Trees and Suffix Arrays Dong Kyue Kim Minhwan Kim
More informationSpace Efficient Linear Time Construction of
Space Efficient Linear Time Construction of Suffix Arrays Pang Ko and Srinivas Aluru Dept. of Electrical and Computer Engineering 1 Laurence H. Baker Center for Bioinformatics and Biological Statistics
More informationLocally Compressed Suffix Arrays
Locally Compressed Suffix Arrays Rodrigo González, Gonzalo Navarro, and Héctor Ferrada Dept. of Computer Science, University of Chile. {rgonzale,gnavarro,hferrada}@dcc.uchile.cl We introduce a compression
More informationA Lempel-Ziv Text Index on Secondary Storage
A Lempel-Ziv Text Index on Secondary Storage Diego Arroyuelo and Gonzalo Navarro Dept. of Computer Science, University of Chile, Blanco Encalada 212, Santiago, Chile. {darroyue,gnavarro}@dcc.uchile.cl
More informationDynamic Extended Suffix Arrays
Dynamic Extended Suffix Arrays M. Salson a,. Lecroq a M. Léonard a L. Mouchard a,b, a Université de Rouen, LIIS EA 408, 768 Mont-Saint-Aignan, France b Algorithm Design Group, Department of omputer Science,
More informationParallel Distributed Memory String Indexes
Parallel Distributed Memory String Indexes Efficient Construction and Querying Patrick Flick & Srinivas Aluru Computational Science and Engineering Georgia Institute of Technology 1 In this talk Overview
More informationOptimal String Mining under Frequency Constraints
Optimal String Mining under Frequency Constraints Johannes Fischer, Volker Heun, and Stefan Kramer 2 Ludwig-Maximilians-Universität München, Institut für Informatik, Amalienstr. 7, D-80333 München {Johannes.Fischer
More informationCSE 5311 Notes 14: Sequences
CSE 5311 Notes 14: Sequences (Last updated 4/19/17 3:56 PM) PATTERN-BASED PREPROCESSING Simple Rescanning Pattern - m symbols Text - n symbols Example: Pattern: A B A C Text: A B A B A B A C A B A B A
More informationSampled longest common prefix array. Sirén, Jouni. Springer 2010
https://helda.helsinki.fi Sampled longest common prefix array Sirén, Jouni Springer 2010 Sirén, J 2010, Sampled longest common prefix array. in A Amir & L Parida (eds), Combinatorial Pattern Matching :
More informationL02 : 08/21/2015 L03 : 08/24/2015.
L02 : 08/21/2015 http://www.csee.wvu.edu/~adjeroh/classes/cs493n/ Multimedia use to be the idea of Big Data Definition of Big Data is moving data (It will be different in 5..10 yrs). Big data is highly
More informationDistributed and Paged Suffix Trees for Large Genetic Databases p.1/18
istributed and Paged Suffix Trees for Large Genetic atabases Raphaël Clifford and Marek Sergot raphael@clifford.net, m.sergot@ic.ac.uk Imperial College London, UK istributed and Paged Suffix Trees for
More informationSuffix Trees. Martin Farach-Colton Rutgers University & Tokutek, Inc
Suffix Trees Martin Farach-Colton Rutgers University & Tokutek, Inc What s in this talk? What s a suffix tree? What can you do with them? How do you build them? A challenge problem What s in this talk?
More informationLinear-Space Data Structures for Range Minority Query in Arrays
Linear-Space Data Structures for Range Minority Query in Arrays Timothy M. Chan 1, Stephane Durocher 2, Matthew Skala 2, and Bryan T. Wilkinson 1 1 Cheriton School of Computer Science, University of Waterloo,
More informationAn introduction to suffix trees and indexing
An introduction to suffix trees and indexing Tomáš Flouri Solon P. Pissis Heidelberg Institute for Theoretical Studies December 3, 2012 1 Introduction Introduction 2 Basic Definitions Graph theory Alphabet
More informationarxiv: v3 [cs.ir] 18 May 2017
Information Retrieval manuscript No. (will be inserted by the editor) Document Retrieval on Repetitive String Collections Travis Gagie Aleksi Hartikainen Kalle Karhu Juha Kärkkäinen Gonzalo Navarro Simon
More informationA Fast Order-Preserving Matching with q-neighborhood Filtration Using SIMD Instructions
A Fast Order-Preserving Matching with q-neighborhood Filtration Using SIMD Instructions Yohei Ueki, Kazuyuki Narisawa, and Ayumi Shinohara Graduate School of Information Sciences, Tohoku University, Japan
More informationA Compressed Text Index on Secondary Memory
A Compressed Text Index on Secondary Memory Rodrigo González and Gonzalo Navarro Department of Computer Science, University of Chile. {rgonzale,gnavarro}@dcc.uchile.cl Abstract. We introduce a practical
More informationCompressed Suffix Trees: Design, Construction, and Applications
Universität Ulm 89069 Ulm Germany Fakultät für Ingenieurwissenschaften und Informatik Institut für Theoretische Informatik Compressed Suffix Trees: Design, Construction, and Applications DISSERTATION zur
More informationAbdullah-Al Mamun. CSE 5095 Yufeng Wu Spring 2013
Abdullah-Al Mamun CSE 5095 Yufeng Wu Spring 2013 Introduction Data compression is the art of reducing the number of bits needed to store or transmit data Compression is closely related to decompression
More informationFrequency Covers for Strings
Fundamenta Informaticae XXI (2018) 1 16 1 DOI 10.3233/FI-2016-0000 IOS Press Frequency Covers for Strings Neerja Mhaskar C Dept. of Computing and Software, McMaster University, Canada pophlin@mcmaster.ca
More information58093 String Processing Algorithms. Lectures, Autumn 2013, period II
58093 String Processing Algorithms Lectures, Autumn 2013, period II Juha Kärkkäinen 1 Contents 0. Introduction 1. Sets of strings Search trees, string sorting, binary search 2. Exact string matching Finding
More informationParallel Lightweight Wavelet-Tree, Suffix-Array and FM-Index Construction
Parallel Lightweight Wavelet-Tree, Suffix-Array and FM-Index Construction Bachelor Thesis of Julian Labeit At the Department of Informatics Institute for Theoretical Computer Science Reviewer: Second reviewer:
More informationData Compression Techniques
Data Compression Techniques Part 1: Entropy Coding Lecture 1: Introduction and Huffman Coding Juha Kärkkäinen 31.10.2017 1 / 21 Introduction Data compression deals with encoding information in as few bits
More informationLongest Common Extensions in Trees
Longest Common Extensions in Trees Philip Bille 1, Pawe l Gawrychowski 2, Inge Li Gørtz 1, Gad M. Landau 3,4, and Oren Weimann 3 1 DTU Informatics, Denmark. phbi@dtu.dk, inge@dtu.dk 2 University of Warsaw,
More informationDO NOT. In the following, long chains of states with a single child are condensed into an edge showing all the letters along the way.
CS61B, Fall 2009 Test #3 Solutions P. N. Hilfinger Unless a question says otherwise, time estimates refer to asymptotic bounds (O( ), Ω( ), Θ( )). Always give the simplest bounds possible (O(f(x)) is simpler
More informationColored Range Queries and Document Retrieval
Colored Range Queries and Document Retrieval Travis Gagie 1, Gonzalo Navarro 1, and Simon J. Puglisi 2 1 Dept. of Computer Science, Univt. of Chile, {tgagie,gnavarro}@dcc.uchile.cl 2 School of Computer
More informationRestricted Transposition Invariant Approximate String Matching Under Edit Distance
Restricted Transposition Invariant Approximate String Matching Under Edit Distance Heikki Hyyrö Department of Computer Sciences, University of Tampere, Finland. heikki.hyyro@gmail.com Abstract. Let A and
More informationCSC 421: Algorithm Design & Analysis. Spring Space vs. time
CSC 421: Algorithm Design & Analysis Spring 2015 Space vs. time space/time tradeoffs examples: heap sort, data structure redundancy, hashing string matching brute force, Horspool algorithm, Boyer-Moore
More informationW O R S T- C A S E L I N E A R T I M E S U F F I X A R - R AY C O N S T R U C T I O N A L G O R I T H M S
W O R S T- C A S E L I N E A R T I M E S U F F I X A R - R AY C O N S T R U C T I O N A L G O R I T H M S mikkel ravnholt knudsen, 201303546 jens christian liingaard hansen, 201303561 master s thesis June
More information