Final Report A

Total Page:16

File Type:pdf, Size:1020Kb

Final Report A au AARHUS UNIVERSITY ),1$/ REPORT Center for Massive Data Algorithmics 2007 - 201 MADALGO - a Center of the Danish National Research Foundation / Department of Computer Science / Aarhus University When initiated in 2007, the ambitious goal of the Danish National Research Foundation Center for Massive Data Algorithmics (MADALGO) was to become a world-leading center in algorithms for handling massive data. The high-level objectives of the center were: x To significantly advance the fundamental algorithms knowledge in the area of efficient processing of massive datasets; x To educate the next generation of researchers in a world-leading and international environment; x To be a catalyst for multidisciplinary collaborative research on massive dataset issues in commercial and scientific applications. Building on the research strength at the main center site at Aarhus University in Denmark, and at the sites of the other participants at Max Planck Institute for Informatics and at Frankfurt University in Germany, and at Massachusetts Institute of Technology in the US, as well as on significant international research collaboration, multidisciplinary and industry collaboration, and in general on a vibrant international environment at the main center site, I believe we have met the goal. Following the guidelines of the Foundation, this report contains a short reflection on the center’s results, impact and international standing (section A), along with appendices with statistics on patents and spin-off companies (section A) and the statistics collected by the Foundation (section C). It also contains 10 publications reflecting the breadth and depth of center research. Lars Arge Center Director May, 2016 Final report A. Center results, impact and international standing Center Results. A key motivation for establishment of Center for Massive Data Algorithmics was the inadequacy of traditional algorithms theory in many applications involving massive amounts of data. In particular, traditional algorithm theory use simplistic machine models (mathematical model in which algorithms are designed and analyzed) that do not take the hierarchical memory organization of modern machines into account. This translates into software inadequacies when processing massive data. Based on an ambitious research plan, center researchers have obtained a large number of results centered around four key areas that all relate to the design of algorithms in more realistic models of computations than traditional algorithm theory. Below we briefly highlight a few results (corresponding to the 10 selected papers). In the area of I/O-efficient algorithms, the goal is to design algorithms in a model of computation that takes the large access time of disk (compared to main memory) into account. Center results on fundamental problems in the area include results on sorting algorithms that are provably optimal in terms of both I/O and internal memory computation time (selected paper 1, which won the best paper awards at the 2013 ISAAC conference). Center researchers have also obtained results on processing of massive terrain data, including several results on modeling water flow on terrains, such as for example algorithms for computing how depressions in a terrain fills with water as it rains (paper 2, which appeared in the top computational geometry conference SoCG). Overall, we believe center work in the area has been very successful. In the area of cache-oblivious algorithms, the aim is to develop algorithms that automatically adapt to the unknown multiple levels of modern memory hierarchies. Developing cache-oblivious algorithms is very challenging; at the start of the center, techniques for obtaining cache-oblivious algorithms was not very developed and the fundamental limitations in the area not well understood. Center researchers have obtained a good number of results in the area, and e.g. developed new fundamental techniques used to obtain an optimal cache-oblivious data structure that allows for fast search for a data element among a set of elements (paper 3, which appeared in the top algorithms conference SODA). However, overall we have not made as much progress on cache-oblivious problems as we would have liked. In the area of streaming algorithms, the aim is to develop algorithms that only perform one sequential pass over the input data, while processing each input element as fast as possible using significantly less space than the input data size. Center researchers have obtained a large number of results in the area. For example, we have developed the first optimal algorithm for the well-studied and fundamental problem of estimating the number of distinct elements in a stream (paper 4, which won the best paper awards at the top theoretical database conference PODS in 2010). We have also obtained a large number of results in relation to the so- called linear sketching technique, and recently we showed the very first known lower bounds on how fast data stream elements can be processed (paper 5, which appeared in the top theoretical computer science conference STOC). Overall, we believe center work in the area has been very successful. The area of algorithm engineering covers the design and analysis of practical algorithms, their efficient implementation, as well as experimentation that provides insight into their applicability and further improvement. Center researches have in particular engineered many I/O-efficient algorithms. For example, the center has had great success with engineering algorithms for flood risk analysis using detailed (and thus massive) terrain data. This work includes implementation of results on how depressions fill during a rain event mentioned above (paper 2) and recent work on modelling and computing flood risk from water rising in rivers (paper 6, which appear in the good geographic information systems conference GIScience). It also formed the basis of the center startup company SCALGO, which has very successfully marketed flood risk analysis products based on the openly available detailed terrain model of Denmark. For example, the depression risk analysis results (paper 2) formed the basis of analysis purchased by more than half of the local Danish governments. Center algorithm engineering work has also formed the basis for collaboration with several other companies, as well as for extensive collaboration with researchers in other fields, in particular biology (bioinformatics and biodiversity) researchers. The river flood risk research (paper 6) is e.g. performed with a number of biology researchers, and the collaboration has also led to a Science paper (paper 7). Overall, we believe center algorithm engineering work has been very successful. In addition to the above four core areas, center researchers have obtained a large number of results on research questions in relation to e.g. models of parallel computation, flash memory, fault tolerance, memory efficient (succinct) data structures, as well as to fundamental problems in more traditional models of computation, in particular data structure and lower bound problems. As a few examples, center researchers have solved longstanding open problems in succinct (paper 8, which won the best student paper award at the top theoretical computer science conference FOCS in 2008) and priority queue (paper 9, which appeared in top theoretical computer science conferences STOC and is co-authored by Turing Award winner Final report Tarjan) data structures. Much of the center’s data structure work (in various models of computation) has been on fundamental range searching problems (storing a set of d-dimensional points such that points in a query range can be identified efficiently), and we have e.g. showed very strong lower bound tradeoffs between search and update time for several variants of the problem (paper 10, which won both best paper and best student paper awards in the top theoretical computer science conferences STOC in 2012). A key goal of the center has been to educate the next generation of researchers in a world-leading and international environment. Altogether, 28 PhD students have graduated from the center (19 from AU), and the center currently houses 14 PhD students (7 at AU). Among the 26 students at AU, 12 students are internationals. Additionally, the center has hosted 24 Post Doc (22 at AU). The center has emphasized creation of a vibrant and international environment at the main center site at AU. The center has hosted numerous research visitors, just as we have organized annual summer schools at the center. The summer school series has been very successful, with around 70 participants from 30+ institutions attending every year. The center has also hosted the top computational geometry conference (SoCG) in 2009, and is hosting the top European algorithms event ALGO (including the top European algorithms conference ESA) in 2016. The center also initiated Workshop on Massive Data Algorithmics (MASSIVE) in 2009 and the successful workshop has been held every year since in connection with SoCG or ALGO. Center international standing and impact. Overall, we believe the center has been very successful. From a purely bibliometric point of view, this can e.g. be seen from the fact that in the last four years, center researchers have published 90+ peer-reviewed papers a year, with consistently 10+ papers in the top three general theoretical computer science conferences STOC, FOCS and SODA. According to google scholar, center papers have received 12.000+ citations (steadily increasing
Recommended publications
  • THE INVARIANCE THESIS 1. Introduction in 1936, Turing [47
    THE INVARIANCE THESIS NACHUM DERSHOWITZ AND EVGENIA FALKOVICH-DERZHAVETZ School of Computer Science, Tel Aviv University, Ramat Aviv, Israel e-mail address:[email protected] School of Computer Science, Tel Aviv University, Ramat Aviv, Israel e-mail address:[email protected] Abstract. We demonstrate that the programs of any classical (sequential, non-interactive) computation model or programming language that satisfies natural postulates of effective- ness (which specialize Gurevich’s Sequential Postulates)—regardless of the data structures it employs—can be simulated by a random access machine (RAM) with only constant factor overhead. In essence, the postulates of algorithmicity and effectiveness assert the following: states can be represented as logical structures; transitions depend on a fixed finite set of terms (those referred to in the algorithm); all atomic operations can be pro- grammed from constructors; and transitions commute with isomorphisms. Complexity for any domain is measured in terms of constructor operations. It follows that any algorithmic lower bounds found for the RAM model also hold (up to a constant factor determined by the algorithm in question) for any and all effective classical models of computation, what- ever their control structures and data structures. This substantiates the Invariance Thesis of van Emde Boas, namely that every effective classical algorithm can be polynomially simulated by a RAM. Specifically, we show that the overhead is only a linear factor in either time or space (and a constant factor in the other dimension). The enormous number of animals in the world depends of their varied structure & complexity: — hence as the forms became complicated, they opened fresh means of adding to their complexity.
    [Show full text]
  • Optimal Multithreaded Batch-Parallel 2-3 Trees Arxiv:1905.05254V2
    Optimal Multithreaded Batch-Parallel 2-3 Trees Wei Quan Lim National University of Singapore Keywords Parallel data structures, pointer machine, multithreading, dictionaries, 2-3 trees. Abstract This paper presents a batch-parallel 2-3 tree T in an asynchronous dynamic multithreading model that supports searches, insertions and deletions in sorted batches and has essentially optimal parallelism, even under the restrictive QRMW (queued read-modify-write) memory contention model where concurrent accesses to the same memory location are queued and serviced one by one. Specifically, if T has n items, then performing an item-sorted batch (given as a leaf-based balanced binary tree) of b operations · n ¹ º ! 1 on T takes O b log b +1 +b work and O logb+logn span (in the worst case as b;n ). This is information-theoretically work-optimal for b ≤ n, and also span-optimal for pointer-based structures. Moreover, it is easy to support optimal intersection, n union and difference of instances of T with sizes m ≤ n, namely within O¹m·log¹ m +1ºº work and O¹log m + log nº span. Furthermore, T supports other batch operations that make it a very useful building block for parallel data structures. To the author’s knowledge, T is the first parallel sorted-set data structure that can be used in an asynchronous multi-processor machine under a memory model with queued contention and yet have asymptotically optimal work and span. In fact, T is designed to have bounded contention and satisfy the claimed work and span bounds regardless of the execution schedule.
    [Show full text]
  • On Data Structures and Memory Models
    2006:24 DOCTORAL T H E SI S On Data Structures and Memory Models Johan Karlsson Luleå University of Technology Department of Computer Science and Electrical Engineering 2006:24|: 402-544|: - -- 06 ⁄24 -- On Data Structures and Memory Models by Johan Karlsson Department of Computer Science and Electrical Engineering Lule˚a University of Technology SE-971 87 Lule˚a, Sweden May 2006 Supervisor Andrej Brodnik, Ph.D., Lule˚a University of Technology, Sweden Abstract In this thesis we study the limitations of data structures and how they can be overcome through careful consideration of the used memory models. The word RAM model represents the memory as a finite set of registers consisting of a constant number of unique bits. From a hardware point of view it is not necessary to arrange the memory as in the word RAM memory model. However, it is the arrangement used in computer hardware today. Registers may in fact share bits, or overlap their bytes, as in the RAM with Byte Overlap (RAMBO) model. This actually means that a physical bit can appear in several registers or even in several positions within one regis- ter. The RAMBO model of computation gives us a huge variety of memory topologies/models depending on the appearance sets of the bits. We show that it is feasible to implement, in hardware, other memory models than the word RAM memory model. We do this by implementing a RAMBO variant on a memory board for the PC100 memory bus. When alternative memory models are allowed, it is possible to solve a number of problems more efficiently than under the word RAM memory model.
    [Show full text]
  • Algorithms: a Quest for Absolute Definitions∗
    Algorithms: A Quest for Absolute De¯nitions¤ Andreas Blassy Yuri Gurevichz Abstract What is an algorithm? The interest in this foundational problem is not only theoretical; applications include speci¯cation, validation and veri¯ca- tion of software and hardware systems. We describe the quest to understand and de¯ne the notion of algorithm. We start with the Church-Turing thesis and contrast Church's and Turing's approaches, and we ¯nish with some recent investigations. Contents 1 Introduction 2 2 The Church-Turing thesis 3 2.1 Church + Turing . 3 2.2 Turing ¡ Church . 4 2.3 Remarks on Turing's analysis . 6 3 Kolmogorov machines and pointer machines 9 4 Related issues 13 4.1 Physics and computations . 13 4.2 Polynomial time Turing's thesis . 14 4.3 Recursion . 15 ¤Bulletin of European Association for Theoretical Computer Science 81, 2003. yPartially supported by NSF grant DMS{0070723 and by a grant from Microsoft Research. Address: Mathematics Department, University of Michigan, Ann Arbor, MI 48109{1109. zMicrosoft Research, One Microsoft Way, Redmond, WA 98052. 1 5 Formalization of sequential algorithms 15 5.1 Sequential Time Postulate . 16 5.2 Small-step algorithms . 17 5.3 Abstract State Postulate . 17 5.4 Bounded Exploration Postulate and the de¯nition of sequential al- gorithms . 19 5.5 Sequential ASMs and the characterization theorem . 20 6 Formalization of parallel algorithms 21 6.1 What parallel algorithms? . 22 6.2 A few words on the axioms for wide-step algorithms . 22 6.3 Wide-step abstract state machines . 23 6.4 The wide-step characterization theorem .
    [Show full text]
  • A Microcoded Machine Simulator and Microcode Assembler in a FORTH Environment A
    A Microcoded Machine Simulator and Microcode Assembler in a FORTH Environment A. Cotterman, R. Dixon, R. Grewe, G. Simpson Department ofComputer Science Wright State University Abstract A FORTH program which provides a design tool for systems which contain a microcoded component was implemented and used in a computer architecture laboratory. The declaration of standard components such as registers, ALUs, busses, memories, and the connections is required. A sequencer and timing signals are implicit in the implementation. The microcode is written in a FORTH-like language which can be executed directly as a simulation or interpreted to produce a fixed horizontal microcode bit pattern for generating ROMs. The direct execution of the microcode commands (rather than producing bit patterns and interpreting those instructions) gives a simpler, faster implementation. Further, the designer may concentrate on developing the design at a block level without considering some ofthe implementation details (such as microcode fields) which might change several times during the design cycle. However, the design is close enough to the hardware to be readily translated. Finally, the fact that the same code used for the simulation may be used for assembly ofthe microcode instructions (after the field patterns have been specified) saves time and reduces errors. 1. Introduction At the Wright State University computer architecture laboratory a microcoded machine simulator and microcode generator have been developed using FORTH. These tools have been used as "hands-on" instructional aids in graduate courses in computer architecture, and are also being used to aid the in-house development of new architectures in ongoing research efforts. The simulator provides basic block-level functional control and data-flow simulation for a machine architecture based on a microcoded implementation.
    [Show full text]
  • Hardware Information Flow Tracking
    Hardware Information Flow Tracking WEI HU, Northwestern Polytechnical University, China ARMAITI ARDESHIRICHAM, University of California, San Diego, USA RYAN KASTNER, University of California, San Diego, USA Information flow tracking (IFT) is a fundamental computer security technique used to understand how information moves througha computing system. Hardware IFT techniques specifically target security vulnerabilities related to the design, verification, testing, man- ufacturing, and deployment of hardware circuits. Hardware IFT can detect unintentional design flaws, malicious circuit modifications, timing side channels, access control violations, and other insecure hardware behaviors. This article surveys the area of hardware IFT. We start with a discussion on the basics of IFT, whose foundations were introduced by Denning in the 1970s. Building upon this, we develop a taxonomy for hardware IFT. We use this to classify and differentiate hardware IFT tools and techniques. Finally, we discuss the challenges yet to be resolved. The survey shows that hardware IFT provides a powerful technique for identifying hardware security vulnerabilities as well as verifying and enforcing hardware security properties. CCS Concepts: • Security and privacy Logic and verification; Information flow control; Formal security models. ! Additional Key Words and Phrases: Hardware security, information flow security, information flow tracking, security verification, formal method, survey ACM Reference Format: Wei Hu, Armaiti Ardeshiricham, and Ryan Kastner. 2020. Hardware Information Flow Tracking. ACM Comput. Surv. 0, 0, Article 00 (April 2020), 38 pages. https://doi.org/10.0000/0000000.0000000 1 INTRODUCTION A core tenet of computer security is to maintain the confidentiality and integrity of the information being computed upon. Confidentiality ensures that information is only disclosed to authorized entities.
    [Show full text]
  • Complexity of Algorithms
    Complexity of Algorithms Lecture Notes, Spring 1999 Peter G´acs Boston University and L´aszl´oLov´asz Yale University 1 Contents 0 Introduction and Preliminaries 1 0.1 Thesubjectofcomplexitytheory . ... 1 0.2 Somenotationanddefinitions . .. 2 1 Models of Computation 3 1.1 Introduction................................... 3 1.2 Finiteautomata ................................ 5 1.3 TheTuringmachine .............................. 7 1.3.1 ThenotionofaTuringmachine. 7 1.3.2 UniversalTuringmachines. 9 1.3.3 Moretapesversusonetape . 11 1.4 TheRandomAccessMachine . 17 1.5 BooleanfunctionsandBooleancircuits. ...... 22 2 Algorithmic decidability 30 2.1 Introduction................................... 30 2.2 Recursive and recursively enumerable languages . ......... 31 2.3 Otherundecidableproblems. .. 35 2.3.1 Thetilingproblem .. .. .. .. .. .. .. .. .. .. .. 35 2.3.2 Famous undecidable problems in mathematics . .... 38 2.4 Computabilityinlogic . 40 2.4.1 Godel’sincompletenesstheorem. .. 40 2.4.2 First-orderlogic ............................ 42 2.4.3 A simple theory of arithmetic; Church’s Theorem . ..... 45 3 Computation with resource bounds 48 3.1 Introduction................................... 48 3.2 Timeandspace................................. 48 3.3 Polynomial time I: Algorithms in arithmetic . ....... 50 3.3.1 Arithmeticoperations . 50 3.3.2 Gaussianelimination. 52 3.4 PolynomialtimeII:Graphalgorithms . .... 55 3.4.1 Howisagraphgiven? . .. .. .. .. .. .. .. .. .. .. 55 3.4.2 Searchingagraph ........................... 55 3.4.3 Maximum bipartite
    [Show full text]
  • Energy-Efficient Algorithms
    Energy-Efficient Algorithms Erik D. Demaine∗ Jayson Lynch∗ Geronimo J. Mirano∗ Nirvan Tyagi∗ May 30, 2016 Abstract We initiate the systematic study of the energy complexity of algorithms (in addition to time and space complexity) based on Landauer's Principle in physics, which gives a lower bound on the amount of energy a system must dissipate if it destroys information. We propose energy- aware variations of three standard models of computation: circuit RAM, word RAM, and trans- dichotomous RAM. On top of these models, we build familiar high-level primitives such as control logic, memory allocation, and garbage collection with zero energy complexity and only constant-factor overheads in space and time complexity, enabling simple expression of energy- efficient algorithms. We analyze several classic algorithms in our models and develop low-energy variations: comparison sort, insertion sort, counting sort, breadth-first search, Bellman-Ford, Floyd-Warshall, matrix all-pairs shortest paths, AVL trees, binary heaps, and dynamic arrays. We explore the time/space/energy trade-off and develop several general techniques for analyzing algorithms and reducing their energy complexity. These results lay a theoretical foundation for a new field of semi-reversible computing and provide a new framework for the investigation of algorithms. Keywords: Reversible Computing, Landauer's Principle, Algorithms, Models of Computation ∗MIT Computer Science and Artificial Intelligence Laboratory, 32 Vassar Street, Cambridge, MA 02139, USA, fedemaine,jaysonl,geronm,[email protected]. Supported in part by the MIT Energy Initiative and by MADALGO | Center for Massive Data Algorithmics | a Center of the Danish National Research Foundation. arXiv:1605.08448v1 [cs.DS] 26 May 2016 Contents 1 Introduction 1 2 Energy Models 4 2.1 Energy Circuit Model .
    [Show full text]
  • The Yesterday, Today, and Tomorrow of Parallelism in Logic Programming
    The Yesterday, Today, and Tomorrow of Parallelism in Logic Programming Enrico Pontelli Department of Computer Science New Mexico State University New Mexico State University Tutorial Roadmap Systems Going clasp Large Basics Prolog ASP Going Small (Early) Yesterday Today Tomorrow KLAP Laboratory New Mexico State University Let’s get Started! KLAP Laboratory New Mexico State University Tutorial Roadmap Systems Going clasp Large Basics Prolog ASP Going Small (Early) Yesterday Today Tomorrow KLAP Laboratory New Mexico State University Prolog Programs • Program = a bunch of axioms • Run your program by: – Enter a series of facts and axioms – Pose a query – System tries to prove your query by finding a series of inference steps • “Philosophically” declarative • Actual implementations are deterministic KLAP Laboratory 5 Horn Clauses (Axioms) • Axioms in logic languages are written: H :- B1, B2,….,B3 Facts = clause with head and no body. Rules = have both head and body. Query – can be thought of as a clause with no body. KLAP Laboratory 6 Terms • H and B are terms. • Terms = – Atoms - begin with lowercase letters: x, y, z, fred – Numbers: integers, reals – Variables - begin with captial letters: X, Y, Z, Alist – Structures: consist of an atom called a functor, and a list of arguments. ex. edge(a,b). line(1,2,4). KLAP Laboratory 7 Backward Chaining START WITH THE GOAL and work backwards, attempting to decompose it into a set of (true) clauses. This is what the Prolog interpreter does. KLAP Laboratory 8 Backtracking search KLAP Laboratory 9 Assumption for this Tutorial CODE AREA TRAIL • BasicHEAP familiarity with Logic ProgrammingTop of Trail Instruction Pointer – Datalog (pure Horn clauses, no function symbols)Return Address Heap Top Prev.
    [Show full text]
  • Computer Science & Engineering
    Punjabi University, Patiala Four Year B.Tech (CSE) Batch 2014 BOS: 2015 B. TECH SECOND YEAR COMPUTER SCIENCE & ENGINEERING (Batch 2014) Session (2015-16) SCHEME OF PAPERS THIRD SEMESTER (COMPUTER SCIENCE & ENGINEERING) S. No. Subject Code Subject Name L T P Cr. 1. ECE-209 Digital Electronic Circuits 3 1 0 3.5 2. CPE-201 Computer Architecture 3 1 0 3.5 3. CPE-202 Object Oriented Programming using C++ 3 1 0 3.5 4. CPE-203 Operating Systems 3 1 0 3.5 5. CPE-205 Discrete Mathematical Structure 3 1 0 3.5 6. CPE-210 Computer Peripheral and Interface 3 1 0 3.5 7. ECE-259 Digital Electronic Circuits Lab 0 0 2 1.0 8. CPE-252 Object Oriented Programming using C++ Lab 0 0 2 1.0 9. CPE-253 Operating System and Hardware Lab 0 0 2 1.0 10. ** Punjabi 3 0 0 Total 18 6 6 24 Total Contact Hours = 30 ECE-259, CPE-252 and CPE-253 are practical papers only. There will not be any theory examination for these papers. * * In addition to above mentioned subjects, there will be an additional course on Punjabi as a qualifying subject. Page 1 of 87 Batch: 2015 (CSE) Punjabi University, Patiala Four Year B.Tech (CSE) Batch 2014 BOS: 2015 B. TECH SECOND YEAR COMPUTER SCIENCE & ENGINEERING (Batch 2014) Session (2015-16) SCHEME OF PAPERS FOURTH SEMESTER (COMPUTER SCIENCE & ENGINEERING) S. No. Subject Code Subject Name L T P Cr. 1. BAS-201 Numerical Methods & Applications 3 1 0 3.5 2.
    [Show full text]
  • Triadic Automata and Machines As Information Transformers
    information Article Triadic Automata and Machines as Information Transformers Mark Burgin Department of Mathematics, University of California, Los Angeles, 520 Portola Plaza, Los Angeles, CA 90095, USA; [email protected] Received: 12 December 2019; Accepted: 31 January 2020; Published: 13 February 2020 Abstract: Algorithms and abstract automata (abstract machines) are used to describe, model, explore and improve computers, cell phones, computer networks, such as the Internet, and processes in them. Traditional models of information processing systems—abstract automata—are aimed at performing transformations of data. These transformations are performed by their hardware (abstract devices) and controlled by their software (programs)—both of which stay unchanged during the whole computational process. However, in physical computers, their software is also changing by special tools such as interpreters, compilers, optimizers and translators. In addition, people change the hardware of their computers by extending the external memory. Moreover, the hardware of computer networks is incessantly altering—new computers and other devices are added while other computers and other devices are disconnected. To better represent these peculiarities of computers and computer networks, we introduce and study a more complete model of computations, which is called a triadic automaton or machine. In contrast to traditional models of computations, triadic automata (machine) perform computational processes transforming not only data but also hardware and programs, which control data transformation. In addition, we further develop taxonomy of classes of automata and machines as well as of individual automata and machines according to information they produce. Keywords: information; automaton; machine; hardware; software; modification; process; inductive; recursive; superrecursive; equivalence 1.
    [Show full text]
  • A Verified Information-Flow Architecture
    A Verified Information-Flow Architecture Arthur Azevedo de Amorim1 Nathan Collins2 Andre´ DeHon1 Delphine Demange1 Cat˘ alin˘ Hrit¸cu1,3 David Pichardie3,4 Benjamin C. Pierce1 Randy Pollack4 Andrew Tolmach2 1University of Pennsylvania 2Portland State University 3INRIA 4Harvard University Abstract 40, etc.] and dynamic [3, 20, 39, 44, etc.] enforcement mecha- SAFE is a clean-slate design for a highly secure computer sys- nisms and a huge literature on their formal properties [19, 40, etc.]. tem, with pervasive mechanisms for tracking and limiting infor- Similarly, operating systems with information-flow tracking have mation flows. At the lowest level, the SAFE hardware supports been a staple of the OS literature for over a decade [28, etc.]. But fine-grained programmable tags, with efficient and flexible prop- progress at the hardware level has been more limited, with most agation and combination of tags as instructions are executed. The proposals concentrating on hardware acceleration for taint-tracking operating system virtualizes these generic facilities to present an schemes [12, 15, 45, 47, etc.]. SAFE extends the state of the art information-flow abstract machine that allows user programs to la- in two significant ways. First, the SAFE machine offers hardware bel sensitive data with rich confidentiality policies. We present a support for sound and efficient purely-dynamic tracking of both ex- formal, machine-checked model of the key hardware and software plicit and implicit flows (i.e., information leaks through both data mechanisms used to control information flow in SAFE and an end- and control flow) for arbitrary machine code programs—not just to-end proof of noninterference for this model.
    [Show full text]