A Theory of Program Refinement

Total Page:16

File Type:pdf, Size:1020Kb

A Theory of Program Refinement A Theory of Program Refinement Ewen W.K.C. Denney Doctor of Philosophy University of Edinburgh 1998 Do mo ph`arantan Abstract We give a canonical program refinement calculus based on the lambda calculus and classical first-order predicate logic, and study its proof theory and seman- tics. The intention is to construct a metalanguage for refinement in which basic principles of program development can be studied. The idea is that it should be possible to induce a refinement calculus in a generic manner from a programming language and a program logic. For con- creteness, we adopt the simply-typed lambda calculus augmented with primitive recursion as a paradigmatic typed functional programming language, and use classical first-order logic as a simple program logic. A key feature is the construction of the refinement calculus in a modular fashion, as the combination of two orthogonal extensions to the underlying pro- gramming language (in this case, the simply-typed lambda calculus). The crucial observation is that a refinement calculus is given by extending a programming language to allow indeterminate expressions (or `stubs') involving the construction `some program x such that P '. Factoring this into `some x:::' and `::: such that P ', we first study extensions to the lambda calculus providing separate analyses of what we might call `true' stubs, and structured specifications. The questions we are concerned with in these calculi are how do stubs interact with the programming language, and what is a suitable notion of structured specification for program development. The full refinement calculus is then constructed in a natural way as the com- bination of these two subcalculi. The claim that the subcalculi are orthogonal extensions to the lambda calculus is justified by a result that a refinement can actually be factored into simpler judgements in the subcalculi, that is, into logical reasoning and simple decomposition. The semantics for the calculi are given using Henkin models with additional structure. Both simply-typed lambda calculus and first-order logic are interpreted using Henkin models themselves. The two subcalculi require some extra structure and the full refinement calculus is modelled by Henkin models with a combination of these extra requirements. There are soundness and completeness results for each calculus, and by virtue of there being certain embeddings of models we can infer that the refinement calculus is a conservative extension of both of the subcalculi which, in turn, are conservative extensions of the lambda calculus. Acknowledgements Thanks to Gordon Plotkin and John Power for supervising this thesis and for providing advice and encouragement. I hope their suffering over my writing has not been in vain. Marcelo Fiori also supervised the early stages. Thanks also to John for his famous chats. I had useful conversations with Alex Bunkenburg, Joe Morris, Alvaro´ Moreira, Masahito Hasegawa, Thomas Kleymann, David Aspinall, and Jitka Stˇr´ıbrn´a. This work was supported by an EPSRC studentship and, in the final year, by a part-time research contract with Gordon Plotkin. This thesis was examined by Don Sannella and Peter O'Hearn. Thanks to them for all their helpful comments. Thanks to Yukki and my parents for their support. agus m`oran taing. Declaration I declare that this thesis was composed by myself and that the work contained therein is my own, except where explicitly stated otherwise in the text. (Ewen W.K.C. Denney) Table of Contents Chapter 1 Introduction 4 1.1RefinementMethodology....................... 5 1.1.1 StepwiseDevelopment.................... 6 1.1.2 ProgrammingKnowledge................... 10 1.2ProgramLogicsandSpecification.................. 12 1.3Calculi................................. 14 1.3.1 RefinementTerms....................... 15 1.3.2 RefinementTypes....................... 17 1.3.3 RefinementCalculus..................... 18 1.4OtherMethodologies......................... 19 1.5Choices................................ 22 1.6RelatedWork............................. 23 1.6.1 RefinementTerms....................... 23 1.6.2 RefinementTypes....................... 25 1.6.3 RefinementCalculi...................... 27 1.7SummaryofThesis.......................... 28 1.8Notation................................ 30 Chapter 2 Preliminaries 32 2.1Simply-typedLambdaCalculus................... 32 2.1.1 Syntax............................. 32 2.1.2 λ×→-AxiomSystems..................... 35 2.1.3 BooleansandNaturals.................... 35 2.2ModelsofSimply-typedLambdaCalculus............. 39 2.3First-orderLogicofSimply-typedLambdaCalculus........ 44 2.4ModelsofFirst-orderLogic..................... 48 Chapter 3 Refinement Terms 52 3.1Introduction.............................. 52 3.2TheCalculus............................. 53 1 Chapter 0 | 2 3.2.1 Syntax............................. 53 3.2.2 Judgements.......................... 55 3.2.3 λ?-AxiomSystems...................... 55 3.3Metatheory.............................. 73 3.4Models................................. 76 3.5First-orderLogicofSimply-typedRefinement........... 83 3.6Conclusions.............................. 87 Chapter 4 Refinement Types 88 4.1Introduction.............................. 88 4.2Example................................ 90 4.3TheCalculus............................. 94 4.3.1 Syntax............................. 94 4.3.2 Judgements.......................... 96 4.3.3 λ(:)-AxiomSystems...................... 97 4.3.4 RulesoftheCalculus..................... 99 4.3.5 BooleansandNaturals.................... 111 4.3.6 Metatheory.......................... 114 4.4Divisionby2Revisited........................ 119 4.5Models................................. 120 4.6Conclusions.............................. 134 Chapter 5 Refinement Calculus 135 5.1Introduction.............................. 135 5.2TheCalculus............................. 137 5.2.1 Syntax............................. 137 5.2.2 Judgements.......................... 139 5.2.3 λv-AxiomSystems...................... 139 5.2.4 RulesoftheCalculus..................... 140 5.3AnExampleofRefinement...................... 154 5.4Comparisons.............................. 159 5.4.1 ExtendedML......................... 159 5.4.2 Aspinall's λASL+ ....................... 160 5.4.3 TypeTheory......................... 161 5.4.4 Lego.............................. 162 5.4.5 RefinementCalculusofBack,MorganandMorris..... 163 5.5Metatheory.............................. 167 5.6Models................................. 177 Chapter 0 | 3 5.6.1 Discussion........................... 178 5.6.2 λv-HenkinModels...................... 179 5.7Conclusion............................... 192 Chapter 6 Conclusions and Further Work 193 6.1Conclusions.............................. 193 6.1.1 RefinementTerms....................... 195 6.1.2 RefinementTypes....................... 195 6.2TechnicalExtensionsandConjectures................ 196 6.3OperationalSemantics........................ 199 6.3.1 RefinementTerms....................... 199 6.3.2 RefinementTypes....................... 202 6.4Annotations.............................. 202 6.5SearchCalculi............................. 203 6.6LogicalVariables........................... 205 6.7SecondOrder:DataRefinement................... 205 6.8FullRecursion............................. 206 6.9ProgramTransformation....................... 206 6.10AbstractViewpoint.......................... 207 6.11AspectsoftheSoftwareLife-cycle.................. 208 6.11.1Prototyping.......................... 208 6.11.2Maintenance.......................... 209 6.11.3ReverseEngineering..................... 209 Appendix A Notation 210 Bibliography 211 Chapter 1 Introduction Program refinement is a programming methodology in which a formal description of what a program should do | a specification | is gradually refined into an executable program satisfying that specification. This thesis is a study of program refinement for a simple idealised program- ming and specification language. Although our analysis is theoretical, we give motivation from practical considerations. The kind of issues with which we are concerned are: • What logical machinery and semantic principles are involved in program refinement? • Are there interesting fragments of refinement calculus which have practical uses? • Given a program logic, what is a suitable specification language based on it for program refinement? • Understanding the general relationship between a refinement calculus, a programming language, and a program logic. • How might the structure of a calculus inform the architecture of tools for program development? Although we pose these questions here in general terms, for concreteness we use typed λ-calculus as a paradigmatic functional programming language, and classical first-order logic as a program logic. It is our hope that by making clear how these choices affect our analysis, we will attain some degree of generality. The significance of these decisions is discussed below. In order to address these questions, we carry out a modular analysis of a simple refinement calculus. We suggest that a refinement calculus can be understood as 4 a combination of two extensions to the underlying programming language | one accounting for specifications, and the other for what we call `pure' refinement. Just as the lambda calculus can be used as a metalanguage for studying func- tional programming languages, so the lambda calculus based refinement calculus we develop could be used as a metalanguage for studying refinement in func- tional programming languages. The interest in studying
Recommended publications
  • Biology, Bioinformatics, Bioengineering, Biophysics, Biostatistics, Neuroscience, Medicine, Ophthalmology, and Dentistry
    Biology, Bioinformatics, Bioengineering, Biophysics, Biostatistics, Neuroscience, Medicine, Ophthalmology, and Dentistry This section contains links to textbooks, books, and articles in digital libraries of several publishers (Springer, Elsevier, Wiley, etc.). Most links will work without login on any campus (or remotely using the institution’s VPN) where the institution (company) subscribes to those digital libraries. For De Gruyter and the associated university presses (Chicago, Columbia, Harvard, Princeton, Yale, etc.) you may have to go through your institution’s library portal first. A red title indicates an excellent item, and a blue title indicates a very good (often introductory) item. A purple year of publication is a warning sign. Titles of Open Access (free access) items are colored green. The library is being converted to conform to the university virtual library model that I developed. This section of the library was updated on 06 September 2021. Professor Joseph Vaisman Computer Science and Engineering Department NYU Tandon School of Engineering This section (and the library as a whole) is a free resource published under Attribution-NonCommercial-NoDerivatives 4.0 International license: You can share – copy and redistribute the material in any medium or format under the following terms: Attribution, NonCommercial, and NoDerivatives. https://creativecommons.org/licenses/by-nc-nd/4.0/ Copyright 2021 Joseph Vaisman Table of Contents Food for Thought Biographies Biology Books Articles Web John Tyler Bonner Morphogenesis Evolution
    [Show full text]
  • Submission Data for 2020-2021 CORE Conference Ranking Process International Conference on Mathematical Foundations of Programming Semantics
    Submission Data for 2020-2021 CORE conference Ranking process International Conference on Mathematical Foundations of Programming Semantics Bartek Klin Conference Details Conference Title: International Conference on Mathematical Foundations of Programming Semantics Acronym : MFPS Requested Rank Rank: B Primarily CS Is this conference primarily a CS venue: True Location Not commonly held within a single country, set of countries, or region. DBLP Link DBLP url: https://dblp.org/db/conf/mfps/index.html FoR Codes For1: 4613 For2: SELECT For3: SELECT Recent Years Proceedings Publishing Style Proceedings Publishing: journal Link to most recent proceedings: https://www.sciencedirect.com/journal/electronic-notes-in-theoretical-computer-science/vol/347/suppl/C Further details: Proceedings published as volumes of Electronic Notes in Theoretical Computer Science, published by Elsevier. Most Recent Years Most Recent Year Year: 2019 URL: https://www.coalg.org/calco-mfps-2019/mfps/ Location: London, UK Papers submitted: 20 Papers published: 15 Acceptance rate: 75 Source for numbers: https://www.coalg.org/calco-mfps-2019/mfps/mfps-xxxv-list-of-accepted-papers/ General Chairs 1 No General Chairs Program Chairs Name: Barbara KÃűnig Affiliation: University of Duisburg-Essen, Germany Gender: F H Index: 27 GScholar url: https://scholar.google.com/citations?user=bcM7IuEAAAAJ DBLP url: Second Most Recent Year Year: 2018 URL: https://www.mathstat.dal.ca/mfps2018/ Location: Halifax, Canada Papers submitted: 24 Papers published: 16 Acceptance rate: 67 Source for
    [Show full text]
  • Part I Background
    Cambridge University Press 978-0-521-19746-5 - Transitions and Trees: An Introduction to Structural Operational Semantics Hans Huttel Excerpt More information PART I BACKGROUND © in this web service Cambridge University Press www.cambridge.org Cambridge University Press 978-0-521-19746-5 - Transitions and Trees: An Introduction to Structural Operational Semantics Hans Huttel Excerpt More information 1 A question of semantics The goal of this chapter is to give the reader a glimpse of the applications and problem areas that have motivated and to this day continue to inspire research in the important area of computer science known as programming language semantics. 1.1 Semantics is the study of meaning Programming language semantics is the study of mathematical models of and methods for describing and reasoning about the behaviour of programs. The word semantics has Greek roots1 and was first used in linguistics. Here, one distinguishes among syntax, the study of the structure of lan- guages, semantics, the study of meaning, and pragmatics, the study of the use of language. In computer science we make a similar distinction between syntax and se- mantics. The languages that we are interested in are programming languages in a very general sense. The ‘meaning’ of a program is its behaviour, and for this reason programming language semantics is the part of programming language theory devoted to the study of program behaviour. Programming language semantics is concerned only with purely internal aspects of program behaviour, namely what happens within a running pro- gram. Program semantics does not claim to be able to address other aspects of program behaviour – e.g.
    [Show full text]
  • Estonian Academy of Sciences Yearbook 2018 XXIV
    Facta non solum verba ESTONIAN ACADEMY OF SCIENCES YEARBOOK FACTS AND FIGURES ANNALES ACADEMIAE SCIENTIARUM ESTONICAE XXIV (51) 2018 TALLINN 2019 This book was compiled by: Jaak Järv (editor-in-chief) Editorial team: Siiri Jakobson, Ebe Pilt, Marika Pärn, Tiina Rahkama, Ülle Raud, Ülle Sirk Translator: Kaija Viitpoom Layout: Erje Hakman Photos: Annika Haas p. 30, 31, 48, Reti Kokk p. 12, 41, 42, 45, 46, 47, 49, 52, 53, Janis Salins p. 33. The rest of the photos are from the archive of the Academy. Thanks to all authos for their contributions: Jaak Aaviksoo, Agnes Aljas, Madis Arukask, Villem Aruoja, Toomas Asser, Jüri Engelbrecht, Arvi Hamburg, Sirje Helme, Marin Jänes, Jelena Kallas, Marko Kass, Meelis Kitsing, Mati Koppel, Kerri Kotta, Urmas Kõljalg, Jakob Kübarsepp, Maris Laan, Marju Luts-Sootak, Märt Läänemets, Olga Mazina, Killu Mei, Andres Metspalu, Leo Mõtus, Peeter Müürsepp, Ülo Niine, Jüri Plado, Katre Pärn, Anu Reinart, Kaido Reivelt, Andrus Ristkok, Ave Soeorg, Tarmo Soomere, Külliki Steinberg, Evelin Tamm, Urmas Tartes, Jaana Tõnisson, Marja Unt, Tiit Vaasma, Rein Vaikmäe, Urmas Varblane, Eero Vasar Printed in Priting House Paar ISSN 1406-1503 (printed version) © EESTI TEADUSTE AKADEEMIA ISSN 2674-2446 (web version) CONTENTS FOREWORD ...........................................................................................................................................5 CHRONICLE 2018 ..................................................................................................................................7 MEMBERSHIP
    [Show full text]
  • From Semantics to Dialectometry
    Contents Preface ix Subjunctions as discourse markers? Stancetaking on the topic ‘insubordi- nate subordination’ Werner Abraham Two-layer networks, non-linear separation, and human learning R. Harald Baayen & Peter Hendrix John’s car repaired. Variation in the position of past participles in the ver- bal cluster in Duth Sjef Barbiers, Hans Bennis & Lote Dros-Hendriks Perception of word stress Leonor van der Bij, Dicky Gilbers & Wolfgang Kehrein Empirical evidence for discourse markers at the lexical level Jelke Bloem Verb phrase ellipsis and sloppy identity: a corpus-based investigation Johan Bos 7 7 Om-omission Gosse Bouma 8 Neural semantics Harm Brouwer, Mathew W. Crocker & Noortje J. Venhuizen 7 9 Liberating Dialectology J. K. Chambers 8 0 A new library for construction of automata Jan Daciuk 9 Generating English paraphrases from logic Dan Flickinger 99 Contents Use and possible improvement of UNESCO’s Atlas of the World’s Lan- guages in Danger Tjeerd de Graaf 09 Assessing smoothing parameters in dialectometry Jack Grieve 9 Finding dialect areas by means of bootstrap clustering Wilbert Heeringa 7 An acoustic analysis of English vowels produced by speakers of seven dif- ferent native-language bakgrounds Vincent J. van Heuven & Charlote S. Gooskens 7 Impersonal passives in German: some corpus evidence Erhard Hinrichs 9 7 In Hülle und Fülle – quantiication at a distance in German, Duth and English Jack Hoeksema 9 8 he interpretation of Duth direct speeh reports by Frisian-Duth bilin- guals Franziska Köder, J. W. van der Meer & Jennifer Spenader 7 9 Mining for parsing failures Daniël de Kok & Gertjan van Noord 8 0 Looking for meaning in names Stasinos Konstantopoulos 9 Second thoughts about the Chomskyan revolution Jan Koster 99 Good maps William A.
    [Show full text]
  • Current Issue of FACS FACTS
    Issue 2021-2 July 2021 FACS A C T S The Newsletter of the Formal Aspects of Computing Science (FACS) Specialist Group ISSN 0950-1231 FACS FACTS Issue 2021-2 July 2021 About FACS FACTS FACS FACTS (ISSN: 0950-1231) is the newsletter of the BCS Specialist Group on Formal Aspects of Computing Science (FACS). FACS FACTS is distributed in electronic form to all FACS members. Submissions to FACS FACTS are always welcome. Please visit the newsletter area of the BCS FACS website for further details at: https://www.bcs.org/membership/member-communities/facs-formal-aspects- of-computing-science-group/newsletters/ Back issues of FACS FACTS are available for download from: https://www.bcs.org/membership/member-communities/facs-formal-aspects- of-computing-science-group/newsletters/back-issues-of-facs-facts/ The FACS FACTS Team Newsletter Editors Tim Denvir [email protected] Brian Monahan [email protected] Editorial Team: Jonathan Bowen, John Cooke, Tim Denvir, Brian Monahan, Margaret West. Contributors to this issue: Jonathan Bowen, Andrew Johnstone, Keith Lines, Brian Monahan, John Tucker, Glynn Winskel BCS-FACS websites BCS: http://www.bcs-facs.org LinkedIn: https://www.linkedin.com/groups/2427579/ Facebook: http://www.facebook.com/pages/BCS-FACS/120243984688255 Wikipedia: http://en.wikipedia.org/wiki/BCS-FACS If you have any questions about BCS-FACS, please send these to Jonathan Bowen at [email protected]. 2 FACS FACTS Issue 2021-2 July 2021 Editorial Dear readers, Welcome to the 2021-2 issue of the FACS FACTS Newsletter. A theme for this issue is suggested by the thought that it is just over 50 years since the birth of Domain Theory1.
    [Show full text]
  • Proceedings Include Papers Addressing Different Topics According to the Current Students’ Interest in Informatics
    Copyright c 2019 FEUP Personal use of this material is permitted. However, permission to reprint/republish this material for advertising or promotional purposes or for creating new collective works for resale or redistribution to servers or lists, or to reuse any part of this work in other works must be obtained from the editors. 1st Edition, 2019 ISBN: 978-972-752-243-9 Editors: A. Augusto Sousa and Carlos Soares Faculty of Engineering of the University of Porto Rua Dr. Roberto Frias, 4200-465 Porto DSIE’19 SECRETARIAT: Faculty of Engineering of the University of Porto Rua Dr. Roberto Frias, s/n 4200-465 Porto, Portugal Telephone: +351 22 508 21 34 Fax: +351 22 508 14 43 E-mail: [email protected] Symposium Website: https://web.fe.up.pt/ prodei/dsie19/index.html FOREWORD STEERING COMMITTEE DSIE - Doctoral Symposium in Informatics Engineering, now in its 14th Edition, is an opportunity for the PhD students of ProDEI (Doctoral Program in Informatics Engineering of FEUP) and MAP-tel (Doctoral Program in Telecommunications of Universities of Minho, Aveiro and Porto) to show up and prove they are ready for starting their respective theses work. DSIE is a series of meetings that started in the first edition of ProDEI, in the scholar year 2005/06; its main goal has always been to provide a forum for discussion on, and demonstration of, the practical application of a variety of scientific and technological research issues, particularly in the context of information technology, computer science and computer engineering. DSIE Symposium comes out as a natural conclusion of a mandatory ProDEI course called "Methodologies for Scientific Research" (MSR), this year also available to MAP-tel students, leading to a formal assessment of the PhD students first year’s learned competencies on those methodologies.
    [Show full text]
  • From Theory to Practice of Algebraic Effects and Handlers
    Report from Dagstuhl Seminar 16112 From Theory to Practice of Algebraic Effects and Handlers Edited by Andrej Bauer1, Martin Hofmann2, Matija Pretnar3, and Jeremy Yallop4 1 University of Ljubljana, SI, [email protected] 2 LMU München, DE, [email protected] 3 University of Ljubljana, SI, [email protected] 4 University of Cambridge, GB, [email protected] Abstract Dagstuhl Seminar 16112 was devoted to research in algebraic effects and handlers, a chapter in the principles of programming languages which addresses computational effects (such as I/O, state, exceptions, nondeterminism, and many others). The speakers and the working groups covered a range of topics, including comparisons between various control mechanisms (handlers vs. delimited control), implementation of an effect system for OCaml, compilation techniques for algebraic effects and handlers, and implementations of effects in Haskell. Seminar March 13–18, 2016 – http://www.dagstuhl.de/16112 1998 ACM Subject Classification D.3 Programming Languages, D.3.3 Language Constructs and Features: Control structures, Polymorphism, F.3 Logics and Meanings of Programs, F.3.1 Specifying and Verifying and Reasoning about Programs, F.3.2 Semantics of Programming Languages, F.3.3 Studies of Program Constructs: Control primitives, Type structure Keywords and phrases algebraic effects, computational effects, handlers, implementation tech- niques, programming languages Digital Object Identifier 10.4230/DagRep.6.3.44 Edited in cooperation with Niels F. W. Voorneveld and Philipp G. Haselwarter 1 Executive Summary Andrej Bauer Martin Hofmann Matija Pretnar Jeremy Yallop License Creative Commons BY 3.0 Unported license © Andrej Bauer, Martin Hofmann, Matija Pretnar, Jeremy Yallop Being no strangers to the Dagstuhl seminars we were delighted to get the opportunity to organize Seminar 16112.
    [Show full text]
  • Free-Algebra Models for the Π-Calculus
    CORE Metadata, citation and similar papers at core.ac.uk Provided by Elsevier - Publisher Connector Theoretical Computer Science 390 (2008) 248–270 www.elsevier.com/locate/tcs Free-algebra models for the π-calculus Ian Stark Laboratory for Foundations of Computer Science, School of Informatics, The University of Edinburgh, Scotland, United Kingdom Abstract The finite π-calculus has an explicit set-theoretic functor-category model that is known to be fully abstract for strong late bisimulation congruence. We characterize this as the initial free algebra for an appropriate set of operations and equations in the enriched Lawvere theories of Plotkin and Power. Thus we obtain a novel algebraic description for models of the π-calculus, and validate an existing construction as the universal such model. The algebraic operations are intuitive, covering name creation, communication of names over channels, and nondeterministic choice; the equations then combine these features in a modular fashion. We work in an enriched setting, over a “possible worlds” category of sets indexed by available names. This expands significantly on the classical notion of algebraic theories: we can specify operations that act only on fresh names, or have arities that vary as processes evolve. Based on our algebraic theory of π we describe a category of models for the π-calculus, and show that they all preserve bisimulation congruence. We develop a direct construction of free models in this category; and generalise previous results to prove that all free-algebra models are fully abstract. We show how local modifications to the theory can give alternative models for πI and the early π-calculus.
    [Show full text]
  • A Model of Cooperative Threads
    Introduction A Language for Cooperative Threads An Elementary Fully Abstract Denotational Semantics An Algebraic View of the Semantics Conclusions A Model of Cooperative Threads Martín Abadi Gordon Plotkin Microsoft Research, Silicon Valley LFCS, University of Edinburgh Logic Seminar, Stanford, 2008 Martín Abadi, Gordon Plotkin A Model of Cooperative Threads Introduction A Language for Cooperative Threads An Elementary Fully Abstract Denotational Semantics An Algebraic View of the Semantics Conclusions Outline 1 Introduction 2 A Language for Cooperative Threads 3 An Elementary Fully Abstract Denotational Semantics Denotational Semantics Adequacy and Full Abstraction 4 An Algebraic View of the Semantics The Algebraic Theory of Effects Resumptions Considered Algebraically Asynchronous Processes Considered Algebraically Processes Considered Algebraically 5 Conclusions Martín Abadi, Gordon Plotkin A Model of Cooperative Threads Introduction A Language for Cooperative Threads An Elementary Fully Abstract Denotational Semantics An Algebraic View of the Semantics Conclusions Cooperative Threads and AME Cooperative Threads run without interruption until they yield control. Interest in such threads has increased recently with the introduction of Automatic Mutual Exclusion (AME) and the problem of programming multicore systems. Martín Abadi, Gordon Plotkin A Model of Cooperative Threads Introduction A Language for Cooperative Threads An Elementary Fully Abstract Denotational Semantics An Algebraic View of the Semantics Conclusions What we do We describe a simple language for cooperative threads and give it a mathematically elementary fully abstract (may) semantics of sets of traces, being transition sequences of, roughly, the form: 0 0 u = (σ1; σ1) ::: (σm; σm) à la Abrahamson, the authors, Brookes etc, but adapted to incorporate thread spawning. Following the algebraic theory of effects, we characterise the semantics using a suitable inequational theory, thereby relating it to standard domain-theoretic notions of resumptions.
    [Show full text]
  • Annual Report 2018
    Annual Report 2018 IST Austria scientists by The Scientists country of previous institution Austria 15.6% Germany 13.8% USA 11.1% of IST Austria UK 7.2% Spain 4.5% France 4.5% Italy 4.2% Scientists come from all over the world to conduct Switzerland 3.6% research at IST Austria. This map provides an overview Czech Republic 3.3% China 3.0% of the nationalities on campus. Russia 2.7% India 2.4% Other 24.1% North America Europe Asia Canada Austria Afghanistan Mexico Belgium China USA Bosnia and India Herzegovina Iran Bulgaria Israel Croatia Japan Cyprus Jordan Czech Republic Nepal Denmark Palestine Estonia Russia Finland Turkey France Vietnam Germany Greece Hungary Italy Lithuania Netherlands Poland Portugal Romania Serbia IST Austria scientists by nationality Slovakia Austria 15.6% Slovenia Germany 11.1% Spain Italy 5.7% South America Sweden Russia 5.1% Argentina Switzerland China 4.8% Bolivia Slovakia 4.5% UK Brazil Hungary 4.2% Ukraine India 4.2% Chile Poland 3.3% Colombia Czech Republic 3.3% France 3.0% Spain 2.7% UK 2.4% Oceania United States 2.4% Australia Other 27.7% Content Introduction Outreach & Events 4 Foreword by the President 70 Outreach and 6 Board Member Statements Science Education 72 Scientific Discourse Institute Development 8 10 Years IST Austria IST Austria's Future 18 A Decade of Growth 76 Technology Transfer 20 A Decade of Science 78 Donors 26 IST Austria at a Glance 28 Campus Life 81 Facts & Figures Education & Career 30 Career Options at IST Austria 32 PhD Students at IST Austria 38 Interns at IST Austria 40 Postdocs at IST Austria 42 IST Austria Alumni 44 New Professors Research & Work 48 Biology 50 Computer Science 52 Mathematics 54 Neuroscience 56 Physics 60 Scientific Service Units 62 Staff Scientists 66 Administration 2 3 Foreword Thomas A.
    [Show full text]
  • Symposium for Gordon Plotkin Edinburgh 07-08/09/2006 from Partial Lambda-Calculus to Monads
    Symposium for Gordon Plotkin Edinburgh 07-08/09/2006 From Partial Lambda-calculus to Monads Eugenio Moggi [email protected] DISI, Univ. of Genova GDP symposium – p.1/11 AIM: recall influence of Plotkin (and others) on my PhD research (and beyond) Mainly overview of published work + personal comments and opinions Please interrupt to correct my account or to add your comments Main focus on Partial lambda-calculus [Mog88] 1984-1988 but work placed in broader context: partiality in: Logic, Algebra, Computability lambda-calculi as: PL [Lan66, Plo75], ML [Sco93, GMW79, Plo85] domain theory [FJM+96]: classical, axiomatic, synthetic Applications of monads [Mac71, Man76] for computational types (lifting and recursion) [Mog89, Mog91] 1988-. in pure functional languages (Haskell) – Wadler et al. for collection types (in databases) – Buneman et al. including recent contributions by Plotkin et al. [HPP02] GDP symposium – p.2/11 1984 reformulation of domain theory using partial continuous maps [Plo85] Previous relevant work (. -1983) 1982 more systematic study of categories of partial maps [Obt86, CO87] partiality in algebraic specifications: [Bur82] partiality in (intuitionistic) logic: LPE [Fou77, Sco79], LPT [Bee85] mismatch between lambda-calculus and programming languages [Plo75] λV CBV axioms (λx.t)v > t[x: =v] and (λx.vx) > v with v: : = x j λx.t values λp is derived from models like λV is derived from operational semantics λV ⊂ λc ⊂ λp are correct (but incomplete) for CBV (on untyped λ-terms) λc on (simply typed) λ-terms is inverse image of
    [Show full text]