Data Structures for Efficient String Algorithms

Total Page:16

File Type:pdf, Size:1020Kb

Data Structures for Efficient String Algorithms Data Structures for Efficient String Algorithms Johannes Fischer M¨unchen 2007 Data Structures for Efficient String Algorithms Johannes Fischer Dissertation an der Fakult¨at f¨ur Mathematik, Informatik und Statistik der Ludwig–Maximilians–Universit¨at M¨unchen vorgelegt von Johannes Fischer aus Kronberg i. Ts. M¨unchen, den 10. Oktober 2007 Erstgutachter: Prof. Dr. Volker Heun Zweitgutachter: Prof. Dr. Enno Ohlebusch Tag der m¨undlichen Pr¨ufung: 8. Oktober 2007 Abstract This thesis deals with data structures that are mostly useful in the area of string matching and string mining. Our main result is an O(n)-time prepro- cessing scheme for an array of n numbers such that subsequent queries asking for the position of a minimum element in a specified interval can be answered in constant time (so-called RMQs for Range Minimum Queries). The space for this data structure is 2n + o(n) bits, which is shown to be asymptotically optimal in a general setting. This improves all previous results on this problem. The main techniques for deriving this result rely on combinatorial properties of arrays and so-called Cartesian Trees. For compressible input arrays we show that further space can be saved, while not affecting the time bounds. For the two-dimensional variant of the RMQ-problem we give a preprocessing scheme with quasi-optimal time bounds, but with an asymptotic increase in space con- sumption of a factor of log n. It is well known that algorithms for answering RMQs in constant time are useful for many different algorithmic tasks (e.g., the computation of lowest common ancestors in trees); in the second part of this thesis we give several new applications of the RMQ-problem. We show that our preprocessing scheme for RMQ (and a variant thereof) leads to improvements in the space- and time- consumption of the Enhanced Suffix Array, a collection of arrays that can be used for many tasks in pattern matching. In particular, we will see that in conjunction with the suffix- and LCP-array 2n + o(n) bits of additional space (coming from our RMQ-scheme) are sufficient to find all occ occurrences of a (usually short) pattern of length m in a (usually long) text of length n in O(mσ + occ) time, where σ denotes the size of the alphabet. This is certainly optimal if the size of the alphabet is constant; for non-constant alphabets we can improve this to O(m log σ+occ) locating time, replacing our original scheme with a data structure of size 2.54 n bits. Again by using RMQs, we then show ≈ how to solve frequency-related string mining tasks in optimal time. In a final chapter we propose a space- and time-optimal algorithm for computing suffix arrays on texts that are logically divided into words, if one is just interested in finding all word-aligned occurrences of a pattern. Apart from the theoretical improvements made in this thesis, most of our algorithms are also of practical value; we underline this fact by empirical tests and comparisons on real-word problem instances. In most cases our algorithms outperform previous approaches by all means. Zusammenfassung Diese Arbeit besch¨aftigt sich mit Datenstrukturen, die insbesondere im String Matching und String Mining Anwendung finden. Das Hauptresultat ist ein O(n)-Konstruktionsalgorithmus f¨ur eine Datenstruktur der Gr¨oße 2n + o(n) Bits, die es erlaubt, f¨ur ein Feld von n Zahlen die Position eines minimalen Ele- ments in einem beliebigen Anfrageintervall in konstanter Zeit zu finden (sog. RMQs f¨ur Range Minimum Queries). Dies verbessert alle vorherigen Resul- tate zu diesem Problem. Die Haupttechniken, die zu diesem Ergebnis f¨uhren, beruhen auf kombinatorischen Eigenschaften von Feldern und sog. Kartesi- schen B¨aumen. Wir zeigen zudem, dass dieses Schema zur Pr¨aprozessierung eines Feldes f¨ur konstante RMQs im allgemeinen Fall asymptotisch optimal ist, man jedoch f¨ur komprimierbare Eingabefelder weiteren Platz einsparen kann, ohne dass die Zeitoptimalit¨at leidet. F¨ur die zweidimensionale Variante des- selben Problems stellen wir einen quasi-zeitoptimalen Algorithmus vor, dessen Platzbedarf jedoch etwas h¨oher ist (asymptotisch um den Faktor log n). Neben den bereits bekannten Algorithmen, die RMQs zur L¨osung bestimmter Probleme verwenden (z.B. die Berechnung niedrigster gemeinsamer Vorfahren in B¨aumen), betrachten wir im zweiten Teil dieser Dissertation neue Anwen- dungen des RMQ-Problems. Wir zeigen, dass die oben genannte Datenstruk- tur (und eine Variante hiervon) zu Verbesserungen im Zeit- und Platzbedarf des Enhanced Suffix Array f¨uhrt, einer Sammlung von Feldern zur L¨osung vieler String-Matching-Probleme. Insbesondere werden wir sehen, dass die 2n + o(n) Bits von unserer RMQ-Struktur an zus¨atzlichem Platz ausreichen, um mit dem Suffix- und LCP-Array alle vk Vorkommen eines (normalerweise kleinen) Suchtextes der L¨ange m in einem (normalerweise großen) Text der L¨ange n in Zeit O(mσ + vk) zu finden, wobei σ die Gr¨oße des Alphabets bezeichnet. F¨ur konstante Alphabetgr¨oßen ist dies sicherlich optimal; im Falle nicht konstanter Alphabetgr¨oßen k¨onnen wir dieses Resultat jedoch verbessern: ca. 2.54 n + o(n) zus¨atzliche Bits reichen aus, um mit dem Suffix- und LCP- Array alle vk Vorkommen eines Suchtextes in Zeit O(m log σ + vk) zu finden. Wiederum durch Anwendung unseres Resultats ¨uber RMQs zeigen wir dann, wie wir h¨aufigkeitsbasierte String-Mining-Anfragen in Textdatenbanken in op- timaler Zeit l¨osen k¨onnen. In einem abschließenden Kapitel geben wir einen zeit- und platzoptimalen Konstruktionsalgorithmus f¨ur Suffix Arrays auf Tex- ten, die in logische Einheiten (z.B. nat¨urlichsprachige W¨orter) eingeteilt sind, wenn man bei der Mustersuche nur an Treffern interessiert ist, die an Wort- grenzen beginnen. Die meisten der in dieser Dissertation vorgestellten Resultate haben neben ihrer theoretischen Relevanz auch praktische Bedeutung; eine Tatsache, die mittels empirischer Tests und Vergleichen auf realen Daten unterstrichen wird. In den meisten F¨allen verbessern unsere neuen Algorithmen die Laufzeiten und den Platzbedarf fr¨uherer Ans¨atze deutlich. CONTENTS 1 Introduction 1 1.1 Synopsis................................ 2 1.2 Practicability of the Results . 5 1.3 PreviousPublications . .. .. .. .. .. .. 5 1.4 A Note on Citation Policy . 6 2 Basic Concepts 7 2.1 ArraysandStrings .......................... 7 2.2 BasicStringMatchingProblems . 8 2.3 SuffixTrees .............................. 9 2.4 Suffix-andLCP-Arrays . 10 2.5 Text Compressibility and Empirical Entropy . 11 2.6 Compact Data Structures for Rank and Select . 12 2.7 Succinct Representations of Suffix- and LCP-Arrays . 13 2.8 Balanced Parentheses Representation of Trees . 14 3 An Optimal Preprocessing Scheme for RMQ 17 3.1 ChapterIntroduction. 17 3.2 PreliminaryDefinitions . 18 3.3 ApplicationsofRMQ.. .. .. .. .. .. .. 19 3.3.1 Computing Lowest Common Ancestors in Trees . 19 3.3.2 Computing Longest Common Extensions of Suffixes . 20 3.3.3 (Re-)Construction of Suffix Links . 21 3.3.4 Document Retrieval Queries . 22 3.3.5 Maximum-Sum Segment Queries . 22 3.3.6 Lempel-Ziv-77 Data Compression . 22 3.4 PreviousResultsonRMQs . 23 3.4.1 The Berkman-Vishkin Algorithm . 23 ix x 3.4.2 Alstrup et al.’s Idea for Handling In-Block-Queries . 25 3.4.3 Sadakane’s Succinct RMQ-Algorithm . 26 3.5 AnImprovedAlgorithm . 29 3.5.1 A New Code for Binary Trees . 30 3.5.2 TheAlgorithm ........................ 36 3.6 ALowerBound............................ 41 3.7 Applications of the New Algorithm . 42 3.7.1 LCAs in Trees with Small Average Degree . 42 3.7.2 An Improved Algorithm for Longest Common Extensions 43 3.8 PracticalConsiderations . 44 3.9 HowtoFurtherReduceSpace . 51 3.9.1 Small “Alphabets” Don’t Help! . 51 3.9.2 CompressionTechniques . 52 3.9.3 Outlook ............................ 55 3.10 SummaryandDiscussion . 56 4 2-Dimensional RMQs 57 4.1 ChapterIntroduction. 57 4.2 Preliminaries ............................. 58 4.3 Methods................................ 58 4.3.1 A General Trick for Query Precomputation . 59 4.3.2 Linear Preprocessing of the First Level . 60 4.3.3 Recursive Partitioning . 62 4.3.4 What’s Left: How to Find the Right Grid . 64 4.4 SummaryandOutlook. .. .. .. .. .. .. 65 5 Improvements in the Enhanced Suffix Array 67 5.1 ChapterIntroduction. 67 5.2 EnhancedSuffixArrays . 68 5.3 An RMQ-based Representation of the Child-Table . 70 5.4 Pattern Matching in O(m Σ )Time................. 71 | | 5.5 Pattern Matching in O(m log Σ )Time .............. 72 | | 5.5.1 BasicIdea........................... 72 5.5.2 A Pseudo-Median Algorithm for RMQ on LCP . 73 5.5.3 SummingUp ......................... 81 6 String Mining Problems 83 6.1 ChapterIntroduction. 83 6.2 FormalProblemDefinition. 84 6.3 TheNewAlgorithm ......................... 86 6.3.1 Preprocessing.. .. .. .. .. .. .. 88 6.3.2 Labeling............................ 89 6.3.3 Extraction........................... 90 6.3.4 ReducingtheSizeoftheOutput . 93 6.4 PracticalPerformance . 94 6.5 Conclusions .............................. 98 xi 7 Suffix Arrays on Words 99 7.1 ChapterIntroduction. 99 7.2 ChapterOutline ...........................101 7.3 Definitions...............................102 7.4 Optimal Construction of the Word Suffix Array . 102 7.5 Word-BasedLCP-Arrays. .105 7.6 SearchingintheWordSuffixArray . 107 7.6.1 Searching in O(m log k)Time................107 7.6.2 Searching in O(m + log k)Time...............109 7.6.3 Searching in O(m Σ ) and O(m log Σ )Time . .109 | | | | 7.7 ExperimentalResults. .110 7.8 Conclusions ..............................116 Summary of Notation 117 Bibliography 119 CHAPTER 1 Introduction The title of this thesis, “Data Structures for Efficient String Algorithms,” al- ready suggests that this work is situated between two main areas of computer science: data structures and string algorithmics, the latter being meant to in- clude both string matching and string mining. However, although almost all of our results on data structures do have applications in string matching, these two terms should not exclusively be seen in conjunction, as more than half of the present text is devoted to a problem whose applicability goes far beyond the area of stringology.
Recommended publications
  • Application of TRIE Data Structure and Corresponding Associative Algorithms for Process Optimization in GRID Environment
    Application of TRIE data structure and corresponding associative algorithms for process optimization in GRID environment V. V. Kashanskya, I. L. Kaftannikovb South Ural State University (National Research University), 76, Lenin prospekt, Chelyabinsk, 454080, Russia E-mail: a [email protected], b [email protected] Growing interest around different BOINC powered projects made volunteer GRID model widely used last years, arranging lots of computational resources in different environments. There are many revealed problems of Big Data and horizontally scalable multiuser systems. This paper provides an analysis of TRIE data structure and possibilities of its application in contemporary volunteer GRID networks, including routing (L3 OSI) and spe- cialized key-value storage engine (L7 OSI). The main goal is to show how TRIE mechanisms can influence de- livery process of the corresponding GRID environment resources and services at different layers of networking abstraction. The relevance of the optimization topic is ensured by the fact that with increasing data flow intensi- ty, the latency of the various linear algorithm based subsystems as well increases. This leads to the general ef- fects, such as unacceptably high transmission time and processing instability. Logically paper can be divided into three parts with summary. The first part provides definition of TRIE and asymptotic estimates of corresponding algorithms (searching, deletion, insertion). The second part is devoted to the problem of routing time reduction by applying TRIE data structure. In particular, we analyze Cisco IOS switching services based on Bitwise TRIE and 256 way TRIE data structures. The third part contains general BOINC architecture review and recommenda- tions for highly-loaded projects.
    [Show full text]
  • C Programming: Data Structures and Algorithms
    C Programming: Data Structures and Algorithms An introduction to elementary programming concepts in C Jack Straub, Instructor Version 2.07 DRAFT C Programming: Data Structures and Algorithms, Version 2.07 DRAFT C Programming: Data Structures and Algorithms Version 2.07 DRAFT Copyright © 1996 through 2006 by Jack Straub ii 08/12/08 C Programming: Data Structures and Algorithms, Version 2.07 DRAFT Table of Contents COURSE OVERVIEW ........................................................................................ IX 1. BASICS.................................................................................................... 13 1.1 Objectives ...................................................................................................................................... 13 1.2 Typedef .......................................................................................................................................... 13 1.2.1 Typedef and Portability ............................................................................................................. 13 1.2.2 Typedef and Structures .............................................................................................................. 14 1.2.3 Typedef and Functions .............................................................................................................. 14 1.3 Pointers and Arrays ..................................................................................................................... 16 1.4 Dynamic Memory Allocation .....................................................................................................
    [Show full text]
  • Abstract Data Types
    Chapter 2 Abstract Data Types The second idea at the core of computer science, along with algorithms, is data. In a modern computer, data consists fundamentally of binary bits, but meaningful data is organized into primitive data types such as integer, real, and boolean and into more complex data structures such as arrays and binary trees. These data types and data structures always come along with associated operations that can be done on the data. For example, the 32-bit int data type is defined both by the fact that a value of type int consists of 32 binary bits but also by the fact that two int values can be added, subtracted, multiplied, compared, and so on. An array is defined both by the fact that it is a sequence of data items of the same basic type, but also by the fact that it is possible to directly access each of the positions in the list based on its numerical index. So the idea of a data type includes a specification of the possible values of that type together with the operations that can be performed on those values. An algorithm is an abstract idea, and a program is an implementation of an algorithm. Similarly, it is useful to be able to work with the abstract idea behind a data type or data structure, without getting bogged down in the implementation details. The abstraction in this case is called an \abstract data type." An abstract data type specifies the values of the type, but not how those values are represented as collections of bits, and it specifies operations on those values in terms of their inputs, outputs, and effects rather than as particular algorithms or program code.
    [Show full text]
  • Data Structures, Buffers, and Interprocess Communication
    Data Structures, Buffers, and Interprocess Communication We’ve looked at several examples of interprocess communication involving the transfer of data from one process to another process. We know of three mechanisms that can be used for this transfer: - Files - Shared Memory - Message Passing The act of transferring data involves one process writing or sending a buffer, and another reading or receiving a buffer. Most of you seem to be getting the basic idea of sending and receiving data for IPC… it’s a lot like reading and writing to a file or stdin and stdout. What seems to be a little confusing though is HOW that data gets copied to a buffer for transmission, and HOW data gets copied out of a buffer after transmission. First… let’s look at a piece of data. typedef struct { char ticker[TICKER_SIZE]; double price; } item; . item next; . The data we want to focus on is “next”. “next” is an object of type “item”. “next” occupies memory in the process. What we’d like to do is send “next” from processA to processB via some kind of IPC. IPC Using File Streams If we were going to use good old C++ filestreams as the IPC mechanism, our code would look something like this to write the file: // processA is the sender… ofstream out; out.open(“myipcfile”); item next; strcpy(next.ticker,”ABC”); next.price = 55; out << next.ticker << “ “ << next.price << endl; out.close(); Notice that we didn’t do this: out << next << endl; Why? Because the “<<” operator doesn’t know what to do with an object of type “item”.
    [Show full text]
  • Subtyping Recursive Types
    ACM Transactions on Programming Languages and Systems, 15(4), pp. 575-631, 1993. Subtyping Recursive Types Roberto M. Amadio1 Luca Cardelli CNRS-CRIN, Nancy DEC, Systems Research Center Abstract We investigate the interactions of subtyping and recursive types, in a simply typed λ-calculus. The two fundamental questions here are whether two (recursive) types are in the subtype relation, and whether a term has a type. To address the first question, we relate various definitions of type equivalence and subtyping that are induced by a model, an ordering on infinite trees, an algorithm, and a set of type rules. We show soundness and completeness between the rules, the algorithm, and the tree semantics. We also prove soundness and a restricted form of completeness for the model. To address the second question, we show that to every pair of types in the subtype relation we can associate a term whose denotation is the uniquely determined coercion map between the two types. Moreover, we derive an algorithm that, when given a term with implicit coercions, can infer its least type whenever possible. 1This author's work has been supported in part by Digital Equipment Corporation and in part by the Stanford-CNR Collaboration Project. Page 1 Contents 1. Introduction 1.1 Types 1.2 Subtypes 1.3 Equality of Recursive Types 1.4 Subtyping of Recursive Types 1.5 Algorithm outline 1.6 Formal development 2. A Simply Typed λ-calculus with Recursive Types 2.1 Types 2.2 Terms 2.3 Equations 3. Tree Ordering 3.1 Subtyping Non-recursive Types 3.2 Folding and Unfolding 3.3 Tree Expansion 3.4 Finite Approximations 4.
    [Show full text]
  • 4 Hash Tables and Associative Arrays
    4 FREE Hash Tables and Associative Arrays If you want to get a book from the central library of the University of Karlsruhe, you have to order the book in advance. The library personnel fetch the book from the stacks and deliver it to a room with 100 shelves. You find your book on a shelf numbered with the last two digits of your library card. Why the last digits and not the leading digits? Probably because this distributes the books more evenly among the shelves. The library cards are numbered consecutively as students sign up, and the University of Karlsruhe was founded in 1825. Therefore, the students enrolled at the same time are likely to have the same leading digits in their card number, and only a few shelves would be in use if the leadingCOPY digits were used. The subject of this chapter is the robust and efficient implementation of the above “delivery shelf data structure”. In computer science, this data structure is known as a hash1 table. Hash tables are one implementation of associative arrays, or dictio- naries. The other implementation is the tree data structures which we shall study in Chap. 7. An associative array is an array with a potentially infinite or at least very large index set, out of which only a small number of indices are actually in use. For example, the potential indices may be all strings, and the indices in use may be all identifiers used in a particular C++ program.Or the potential indices may be all ways of placing chess pieces on a chess board, and the indices in use may be the place- ments required in the analysis of a particular game.
    [Show full text]
  • CSE 307: Principles of Programming Languages Classes and Inheritance
    OOP Introduction Type & Subtype Inheritance Overloading and Overriding CSE 307: Principles of Programming Languages Classes and Inheritance R. Sekar 1 / 52 OOP Introduction Type & Subtype Inheritance Overloading and Overriding Topics 1. OOP Introduction 3. Inheritance 2. Type & Subtype 4. Overloading and Overriding 2 / 52 OOP Introduction Type & Subtype Inheritance Overloading and Overriding Section 1 OOP Introduction 3 / 52 OOP Introduction Type & Subtype Inheritance Overloading and Overriding OOP (Object Oriented Programming) So far the languages that we encountered treat data and computation separately. In OOP, the data and computation are combined into an “object”. 4 / 52 OOP Introduction Type & Subtype Inheritance Overloading and Overriding Benefits of OOP more convenient: collects related information together, rather than distributing it. Example: C++ iostream class collects all I/O related operations together into one central place. Contrast with C I/O library, which consists of many distinct functions such as getchar, printf, scanf, sscanf, etc. centralizes and regulates access to data. If there is an error that corrupts object data, we need to look for the error only within its class Contrast with C programs, where access/modification code is distributed throughout the program 5 / 52 OOP Introduction Type & Subtype Inheritance Overloading and Overriding Benefits of OOP (Continued) Promotes reuse. by separating interface from implementation. We can replace the implementation of an object without changing client code. Contrast with C, where the implementation of a data structure such as a linked list is integrated into the client code by permitting extension of new objects via inheritance. Inheritance allows a new class to reuse the features of an existing class.
    [Show full text]
  • Data Structures Using “C”
    DATA STRUCTURES USING “C” DATA STRUCTURES USING “C” LECTURE NOTES Prepared by Dr. Subasish Mohapatra Department of Computer Science and Application College of Engineering and Technology, Bhubaneswar Biju Patnaik University of Technology, Odisha SYLLABUS BE 2106 DATA STRUCTURE (3-0-0) Module – I Introduction to data structures: storage structure for arrays, sparse matrices, Stacks and Queues: representation and application. Linked lists: Single linked lists, linked list representation of stacks and Queues. Operations on polynomials, Double linked list, circular list. Module – II Dynamic storage management-garbage collection and compaction, infix to post fix conversion, postfix expression evaluation. Trees: Tree terminology, Binary tree, Binary search tree, General tree, B+ tree, AVL Tree, Complete Binary Tree representation, Tree traversals, operation on Binary tree-expression Manipulation. Module –III Graphs: Graph terminology, Representation of graphs, path matrix, BFS (breadth first search), DFS (depth first search), topological sorting, Warshall’s algorithm (shortest path algorithm.) Sorting and Searching techniques – Bubble sort, selection sort, Insertion sort, Quick sort, merge sort, Heap sort, Radix sort. Linear and binary search methods, Hashing techniques and hash functions. Text Books: 1. Gilberg and Forouzan: “Data Structure- A Pseudo code approach with C” by Thomson publication 2. “Data structure in C” by Tanenbaum, PHI publication / Pearson publication. 3. Pai: ”Data Structures & Algorithms; Concepts, Techniques & Algorithms
    [Show full text]
  • 1 Abstract Data Types, Cost Specifications, and Data Structures
    Parallel and Sequential Data Structures and Algorithms — Lecture 5 15-210 (Fall 2012) Lecture 5 — Data Abstraction and Sequences I Parallel and Sequential Data Structures and Algorithms, 15-210 (Fall 2012) Lectured by Guy Blelloch — 11 Septermber 2012 Material in this lecture: - Relationship between ADTs, cost specifications and data structures. - The sequence ADT - The scan operation: examples and implementation - Using contraction : an algorithmic technique 1 Abstract Data Types, Cost Specifications, and Data Structures So far in class we have defined several “problems” and discussed algorithms for solving them. The idea is that the problem is an abstract definition of what we want in terms of a function specification, and the algorithms are particular ways to solve/implement the problem. In addition to abstract functions we also often need to define abstractions over data. In such an abstraction we define a set of functions (abstractly) over a common data type. As mentioned in the first lecture, we will refer to the abstractions as abstract data types and their implementations as data structures. An example of an abstract data type, or ADT, you should have seen before is a priority queue. Let’s consider a slight extension where in addition to insert, and deleteMin, we will add a function that joins two priority queues into a single one. For historical reasons, we will call such a join a meld, and the ADT a "meldable priority queue". As with a problem, we like to have a formal definition of the abstract data type. Definition 1.1. Given a totally
    [Show full text]
  • A Metaobject Protocol for Fault-Tolerant CORBA Applications
    A Metaobject Protocol for Fault-Tolerant CORBA Applications Marc-Olivier Killijian*, Jean-Charles Fabre*, Juan-Carlos Ruiz-Garcia*, Shigeru Chiba** *LAAS-CNRS, 7 Avenue du Colonel Roche **Institute of Information Science and 31077 Toulouse cedex, France Electronics, University of Tsukuba, Tennodai, Tsukuba, Ibaraki 305-8573, Japan Abstract The corner stone of a fault-tolerant reflective The use of metalevel architectures for the architecture is the MOP. We thus propose a special implementation of fault-tolerant systems is today very purpose MOP to address the problems of general-purpose appealing. Nevertheless, all such fault-tolerant systems ones. We show that compile-time reflection is a good have used a general-purpose metaobject protocol (MOP) approach for developing a specialized runtime MOP. or are based on restricted reflective features of some The definition and the implementation of an object-oriented language. According to our past appropriate runtime metaobject protocol for implementing experience, we define in this paper a suitable metaobject fault tolerance into CORBA applications is the main protocol, called FT-MOP for building fault-tolerant contribution of the work reported in this paper. This systems. We explain how to realize a specialized runtime MOP, called FT-MOP (Fault Tolerance - MetaObject MOP using compile-time reflection. This MOP is CORBA Protocol), is sufficiently general to be used for other aims compliant: it enables the execution and the state evolution (mobility, adaptability, migration, security). FT-MOP of CORBA objects to be controlled and enables the fault provides a mean to attach dynamically fault tolerance tolerance metalevel to be developed as CORBA software. strategies to CORBA objects as CORBA metaobjects, enabling thus these strategies to be implemented as 1 .
    [Show full text]
  • Space-Efficient Data Structures for String Searching and Retrieval
    Louisiana State University LSU Digital Commons LSU Doctoral Dissertations Graduate School 2014 Space-efficient data structures for string searching and retrieval Sharma Valliyil Thankachan Louisiana State University and Agricultural and Mechanical College, [email protected] Follow this and additional works at: https://digitalcommons.lsu.edu/gradschool_dissertations Part of the Computer Sciences Commons Recommended Citation Valliyil Thankachan, Sharma, "Space-efficient data structures for string searching and retrieval" (2014). LSU Doctoral Dissertations. 2848. https://digitalcommons.lsu.edu/gradschool_dissertations/2848 This Dissertation is brought to you for free and open access by the Graduate School at LSU Digital Commons. It has been accepted for inclusion in LSU Doctoral Dissertations by an authorized graduate school editor of LSU Digital Commons. For more information, please [email protected]. SPACE-EFFICIENT DATA STRUCTURES FOR STRING SEARCHING AND RETRIEVAL A Dissertation Submitted to the Graduate Faculty of the Louisiana State University and Agricultural and Mechanical College in partial fulfillment of the requirements for the degree of Doctor of Philosophy in The Department of Computer Science by Sharma Valliyil Thankachan B.Tech., National Institute of Technology Calicut, 2006 May 2014 Dedicated to the memory of my Grandfather. ii Acknowledgments This thesis would not have been possible without the time and effort of few people, who believed in me, instilled in me the courage to move forward and lent a supportive shoulder in times of uncertainty. I would like to express here how much it all meant to me. First and foremost, I would like to extend my sincerest gratitude to my advisor Dr. Rahul Shah. I would have hardly imagined that a fortuitous encounter in an online puzzle forum with Rahul, would set the stage for a career in theoretical computer science.
    [Show full text]
  • Succinct Permutation Graphs and Graph Isomorphism [5]
    Succinct Permutation Graphs Konstantinos Tsakalidis∗ Sebastian Wild† Viktor Zamaraev‡ October 9, 2020 Abstract We present a succinct, i.e., asymptotically space-optimal, data structure for permuta- tion graphs that supports distance, adjacency, neighborhood and shortest-path queries in optimal time; a variant of our data structure also supports degree queries in time indepen- dent of the neighborhood’s size at the expense of an O(log n/ log log n)-factor overhead in all running times. We show how to generalize our data structure to the class of circular permutation graphs with asymptotically no extra space, while supporting the same queries in optimal time. Furthermore, we develop a similar compact data structure for the special case of bipartite permutation graphs and conjecture that it is succinct for this class. We demonstrate how to execute algorithms directly over our succinct representations for sev- eral combinatorial problems on permutation graphs: Clique, Coloring, Independent Set, Hamiltonian Cycle, All-Pair Shortest Paths, and others. Moreover, we initiate the study of semi-local graph representations; a concept that “in- terpolates” between local labeling schemes and standard “centralized” data structures. We show how to turn some of our data structures into semi-local representations by storing only O(n) bits of additional global information, beating the lower bound on distance labeling schemes for permutation graphs. 1 Introduction As a result of the rapid growth of electronic data sets, memory requirements become a bottle- neck in many applications, as performance usually drops dramatically as soon as data structures do no longer fit into faster levels of the memory hierarchy in computer systems.
    [Show full text]