Finite-State Abstractions for Probabilistic Computation Tree Logic

Total Page:16

File Type:pdf, Size:1020Kb

Finite-State Abstractions for Probabilistic Computation Tree Logic Imperial College London Department of Computing Finite-State Abstractions for Probabilistic Computation Tree Logic Daniel Wagner 2011 Supervised by Dr. Michael Huth Submitted in part fulfilment of the requirements for the degree of Doctor of Philosophy in Computing of Imperial College London and the Diploma of Imperial College London Declaration I herewith certify that all material in this dissertation which is not my own work has been duly acknowledged. Selected results from this dissertation have been disseminated in scientific publications as detailed in Chapter 1.10. Daniel Wagner 2 Abstract Probabilistic Computation Tree Logic (PCTL) is the established temporal logic for probabilistic verification of discrete-time Markov chains. Probabilis- tic model checking is a technique that verifies or refutes whether a property specified in this logic holds in a Markov chain. But Markov chains are of- ten infinite or too large for this technique to apply. A standard solution to this problem is to convert the Markov chain to an abstract model and to model check that abstract model. The problem this thesis therefore stud- ies is whether or when such finite abstractions of Markov chains for model checking PCTL exist. This thesis makes the following contributions. We identify a sizeable frag- ment of PCTL for which 3-valued Markov chains can serve as finite abstrac- tions; this fragment is maximal for those abstractions and subsumes many practically relevant specifications including, e.g., reachability. We also de- velop game-theoretic foundations for the semantics of PCTL over Markov chains by capturing the standard PCTL semantics via a two-player games. These games, finally, inspire a notion of p-automata, which accept entire Markov chains. We show that p-automata subsume PCTL and Markov chains; that their languages of Markov chains have pleasant closure proper- ties; and that the complexity of deciding acceptance matches that of proba- bilistic model checking for p-automata representing PCTL formulae. In ad- dition, we offer a simulation between p-automata that under-approximates language containment. These results then allow us to show that p-automata comprise a solution to the problem studied in this thesis. 3 Contents 1 Introduction 8 1.1 Model checking . 10 1.2 Abstraction and refinement . 12 1.3 (Finitary) completeness . 14 1.4 Finite model property . 16 1.5 Abstraction and undecidability . 18 1.6 Witnesses for truth and falsity . 19 1.7 Research agenda of this thesis . 22 1.8 Achievements in this thesis . 24 1.9 Outline of this thesis . 25 1.10 Publications . 27 1.11 Summary of chapter . 28 2 Background on Models and Logics 29 2.1 Kripke structures . 30 2.2 Linear-time and branching-time temporal logic . 36 2.3 Simulation and bisimulation . 51 2.4 Markov chains and Markov decision processes . 60 2.5 Probabilistic branching-time logic: PCTL . 65 2.6 Probabilistic simulation and bisimulation . 76 2.7 Unfoldings . 79 2.8 Summary of chapter . 83 3 Background on Automata and Games 85 3.1 Word automata . 86 3.2 Probabilistic automata . 95 3.3 Alternating tree automata . 99 3.4 Hintikka games . 107 3.5 Stochastic parity games . 109 4 3.6 Summary of chapter . 112 4 Completeness for a Fragment of PCTL 114 4.1 Existing results . 114 4.2 Our setting: Markov chains and PCTL . 117 4.3 Completeness for a fragment of PCTL via 3-valued unfoldings 118 4.4 Summary of chapter . 131 5 A Game Semantics for PCTL 132 5.1 Game semantics . 132 5.2 Winning strategies . 149 5.3 Summary of chapter . 158 6 Completeness for full PCTL via p-Automata 159 6.1 p-Automata . 160 6.2 Acceptance games . 165 6.3 Expressiveness of p-automata . 173 6.4 Simulation of p-automata . 186 6.5 Wrong embedding of Markov chains . 203 6.6 Summary of chapter . 205 7 Evaluation 206 7.1 Related work on completeness of abstractions . 206 7.2 Evaluation of achievements . 209 7.3 Future work . 210 Bibliography 213 5 List of Figures 2.1 A Kripke structure K....................... 33 2.2 A labelled transition system (T; s0)............... 34 2.3 A partial Kripke structure (K; s0)................ 35 2.4 Hasse diagram of the information order on ftt; ?; ffg...... 36 2.5 A Kripke structure C....................... 53 2.6 A Kripke structure A....................... 53 2.7 A Kripke structure M....................... 54 2.8 A Kripke structure N....................... 55 2.9 A Kripke structure L....................... 56 2.10 A Kripke structure A....................... 58 2.11 A Kripke structure C....................... 58 2.12 A labelled discrete-time Markov chain M............ 63 2.13 A 3-valued discrete-time Markov chain M............ 64 2.14 A Markov decision process M................... 65 2.15 A Markov chain M........................ 68 2.16 A Markov chain M........................ 69 2.17 A Markov chain M........................ 78 2.18 A Markov chain N......................... 78 2.19 A Markov chain B......................... 80 2.20 A Markov chain M........................ 82 s0 2.21 The finite unfolding M3;3..................... 82 3.1 A deterministic word automaton A................ 88 3.2 A deterministic Büchi automaton A............... 90 3.3 A deterministic Büchi automaton B............... 91 3.4 A non-deterministic Büchi automaton C............. 94 3.5 A non-deterministic Büchi automaton A............. 95 3.6 A probabilistic automaton A................... 97 3.7 A probabilistic automaton C................... 98 6 3.8 A probabilistic automaton D................... 98 3.9 A Kripke structure M....................... 104 3.10 An accepting run of B on M................... 104 4.1 A labelled Markov chain M.................... 124 s0 4.2 The finite unfolding M2 ..................... 124 4.3 Maximal height of an unfolding. 127 4.4 A concrete Markov chain M................... 129 6.1 Graph GA of automaton A.................... 163 6.2 A Markov chain M........................ 164 6.3 Case 3 of acceptance game. 171 6.4 Case 1 of acceptance game. 172 6.5 A Markov chain M........................ 204 7 1 Introduction Computing is becoming an ubiquitous part of our lives and an irreplaceable factor in our modern society. Our daily lives and our society as a whole are becoming more and more reliant and dependent on computer systems and their well-functioning. At the same time the various computer systems and especially interaction between them become more and more complex. The systems grow in size and in complexity as well as in sheer number and interconnectivity. Few systems are truly self-contained and many of them interact with each other and with changing and partially unknown environments. The need to understand such systems and their interaction, and the need to be sure about their functionality and their behaviour is becoming more and more pressing. The size and complexity of such systems makes manual inspections obviously infeasible. Furthermore one would like to be able to audit a system on more than one level between the high- level specification and the source code. Actually, one would like to audit systems at all levels between high-level specification and source code, or at least to understand the relationship between the properties of the system in its various descriptions. The result of such an audit should be a rigorous verification and should be fully integrated in the engineering process. The importance of (automatic) formal verification of system behaviour has been recognised early on in the history of computing. According to Cliff Jones [107] already some of the work by Herman Goldstine and John von Neumann [83], by Alan Turing [171] and somehow even the “pre-electronic” work by Charles Babbage [15] was concerned with (the formal verification of) the correctness of programs. It was in the 1960s that the research in formal verification and program analysis truly took off the ground [95, 137, 119]. Since then – with the growing importance of computer systems for industry and society – the need for efficient automatic verification techniques is becoming increasingly important, both economically and socially. Although posed early on, the problem is far from solved. Essentially, 8 the underlying, fundamental problems are undecidable and so incomplete methods are required. Many verification techniques have been suggested, analysed and deployed in applications, but all of them – even for decidable settings – struggle to keep up with the growth in size and complexity of current systems. Formal verification of system behaviour therefore remains an important and active research area. The importance of formal verification was recently acknowledged by Tony Hoare’s declaration of The verifying compiler as one of the Grand Chal- lenges in Computing [96], and by the UK Computing Research Commit- tee (UKCRC) whose Grand Challenge 6 is Dependable Systems Evolution [183, 182]. These Verification Grand Challenges found strong support in the scientific community. Motivating examples, cases of support, different approaches and perspectives were presented, for example, in the position papers presented at the conference “Verified Software: Theories, Tools, Ex- periments”, which was held at the ETH Zürich in 2005 [2]. As the motivation for their Grand Challenge 6 the UKCRC formulates the general need for a notion of justification and dependability: The vision of GC6 is of a future in which all computer systems justify the trust that society increasingly places in them. De- pendability is a multi-faceted notion which includes fault toler- ance, requirements engineering and verification amongst other topics. This broad definition is not restricted to formal verification but also includes other evaluations of evolving and interacting systems. The available means for evaluating systems are broad, ranging from testing and numerical sim- ulation to the formally rigorous approaches such as theorem proving and model checking. In model checking [69, 42, 155, 154], which this thesis is concerned with, one tries to formally answer a query about a system, such as “After each computation, will the program go back to its idle mode?” In model checking the returned answer is usually rigorously proved as opposed to the approximative nature of, say, testing and Monte Carlo simulation.
Recommended publications
  • Reasoning in the Temporal Logic of Actions Basic Research in Computer Science
    BRICS BRICS DS-96-1 U. Engberg: Reasoning in the Temporal Logic of Actions Basic Research in Computer Science Reasoning in the Temporal Logic of Actions The design and implementation of an interactive computer system Urban Engberg BRICS Dissertation Series DS-96-1 ISSN 1396-7002 August 1996 Copyright c 1996, BRICS, Department of Computer Science University of Aarhus. All rights reserved. Reproduction of all or part of this work is permitted for educational or research use on condition that this copyright notice is included in any copy. See back inner page for a list of recent publications in the BRICS Dissertation Series. Copies may be obtained by contacting: BRICS Department of Computer Science University of Aarhus Ny Munkegade, building 540 DK - 8000 Aarhus C Denmark Telephone: +45 8942 3360 Telefax: +45 8942 3255 Internet: [email protected] BRICS publications are in general accessible through WWW and anonymous FTP: http://www.brics.dk/ ftp ftp.brics.dk (cd pub/BRICS) Reasoning in the Temporal Logic of Actions The design and implementation of an interactive computer system Urban Engberg Ph.D. Dissertation Department of Computer Science University of Aarhus Denmark Reasoning in the Temporal Logic of Actions The design and implementation of an interactive computer system A Dissertation Presented to the Faculty of Science of the University of Aarhus in Partial Fulfillment of the Requirements for the Ph.D. Degree by Urban Engberg September 1995 Abstract Reasoning about algorithms stands out as an essential challenge of computer science. Much work has been put into the development of formal methods, within recent years focusing especially on concurrent algorithms.
    [Show full text]
  • Alternation-Free Modal Mu-Calculus for Data Trees (Extended Abstract)
    Alternation-free modal mu-calculus for data trees (Extended abstract) Marcin Jurdzi´nski and Ranko Lazi´c∗ Department of Computer Science, University of Warwick, UK Abstract The recent survey by Segoufin [30] summarises the sub- stantial progress made on reasoning about data words and An alternation-free modal µ-calculus over data trees is data trees. A data word is a word over a finite alphabet, introduced and studied. A data tree is an unranked or- with an equivalence relation on word positions. Implicitly, dered tree whose every node is labelled by a letter from every word position is labelled by an element (“datum”) a finite alphabet and an element (“datum”) from an infi- from an infinite set (“data domain”), but since the infinite nite set. For expressing data-sensitive properties, the calcu- set is equipped only with the equality predicate, it suffices lus is equipped with freeze quantification. A freeze quanti- to know which word positions are labelled by equal data, fier stores in a register the datum labelling the current tree and that is what the equivalence relation represents. Simi- node, which can then be accessed for equality comparisons larly, a data tree is a tree (countable, unranked and ordered) deeper in the formula. whose every node is labelled by a letter from a finite alpha- The main results in the paper are that, for the fragment bet, with an equivalence relation on the set of its nodes. with forward modal operators and one register, satisfiabi- First-order logic for data words was considered in [5], lity over finite data trees is decidable but not primitive re- where variables range over word positions ({0,...,l− 1} cursive, and that for the subfragment consisting of safety or N), there is a unary predicate for each letter from the formulae, satisfiability over countable data trees is decid- finite alphabet, and there is a binary predicate x ∼ y for able but not elementary.
    [Show full text]
  • Lecture 7: Computation Tree Logics
    Lecture 7: Computation Tree Logics Model of Computation Computation Tree Logics The Logic CTL Path Formulas and State Formulas CTL and LTL Expressive Power of Logics 1 Model of Computation a b State Transition Graph or Kripke Model b c c a b b c c a b c c Infinite Computation Tree (Unwind State Graph to obtain Infinite Tree) 2 Model of Computation (Cont.) Formally, a Kripke structure is a triple , where is the set of states, is the transition relation, and gives the set of atomic propositions true in each state. We assume that is total (i.e., for all states there exists a state such that ). A path in M is an infinite sequence of states, such that for , . We write to denote the suffix of starting at . Unless otherwise stated, all of our results apply only to finite Kripke structures. 3 Computation Tree Logics Temporal logics may differ according to how they handle branching in the underlying computation tree. In a linear temporal logic, operators are provided for describing events along a single computation path. In a branching-time logic the temporal operators quantify over the paths that are possible from a given state. 4 The Logic CTL The computation tree logic CTL combines both branching-time and linear-time operators. In this logic a path quantifier can prefix an assertion composed of arbitrary combinations of the usual linear-time operators. 1. Path quantifier: A—“for every path” E—“there exists a path” 2. Linear-time operators: X — holds next time. F — holds sometime in the future G — holds globally in the future U — holds until holds 5 Path Formulas and State Formulas The syntax of state formulas is given by the following rules: If , then is a state formula.
    [Show full text]
  • Computation Tree Logic Is Equivalent to Failure Trace Testing
    COMPUTATION TREE LOGIC IS EQUIVALENT TO FAILURE TRACE TESTING by A. F. M. NOKIB UDDIN A thesis submitted to the Department of Computer Science in conformity with the requirements for the degree of Master of Science Bishop’s University Sherbrooke, Quebec, Canada July 2015 Copyright c A. F. M. Nokib Uddin, 2015 Abstract The two major systems of formal verification are model checking and algebraic techniques such as model-based testing. Model checking is based on some form of temporal logic such as linear temporal logic (LTL) or computation tree logic (CTL). CTL in particular is capable of expressing most interesting properties of processes such as liveness and safety. Alge- braic techniques are based on some operational semantics of processes (such as traces and failures) and its associated preorders. The most fine-grained practical preorder is based on failure traces. The particular algebraic technique for formal verification based on failure traces is failure trace testing. It was shown earlier [8] that CTL and failure trace testing are equivalent; that is, for any failure trace test there exists a CTL formula equivalent to it, and the other way around. Both conversions are constructive and algorithmic. The proof of the conversion from fail- ure trace tests to CTL formulae and implicitly the associated algorithm is however incor- rect [6]. We now provide a correct proof for the existence of a conversion from failure trace tests to CTL formulae. We also offer intuitive support for our proof by providing worked ex- amples related to the examples used earlier [9] to support the conversion the other way around, thus going full circle not only with the conversion but also with our examples.
    [Show full text]
  • Model Checking with Mbeddr
    Model Checking for State Machines with mbeddr and NuSMV 1 Abstract State machines are a powerful tool for modelling software. Particularly in the field of embedded software development where parts of a system can be abstracted as state machine. Temporal logic languages can be used to formulate desired behaviour of a state machine. NuSMV allows to automatically proof whether a state machine complies with properties given as temporal logic formulas. mbedder is an integrated development environment for the C programming language. It enhances C with a special syntax for state machines. Furthermore, it can automatically translate the code into the input language for NuSMV. Thus, it is possible to make use of state-of-the-art mathematical proofing technologies without the need of error prone and time consuming manual translation. This paper gives an introduction to the subject of model checking state machines and how it can be done with mbeddr. It starts with an explanation of temporal logic languages. Afterwards, some features of mbeddr regarding state machines and their verification are discussed, followed by a short description of how NuSMV works. Author: Christoph Rosenberger Supervising Tutor: Peter Sommerlad Lecture: Seminar Program Analysis and Transformation Term: Spring 2013 School: HSR, Hochschule für Technik Rapperswil Model Checking with mbeddr 2 Introduction Model checking In the words of Cavada et al.: „The main purpose of a model checker is to verify that a model satisfies a set of desired properties specified by the user.” [1] mbeddr As Ratiu et al. state in their paper “Language Engineering as an Enabler for Incrementally Defined Formal Analyses” [2], the semantic gap between general purpose programming languages and input languages for formal verification tools is too big.
    [Show full text]
  • Model Checking
    1 MODEL CHECKING Arie Gurfinkel 2 Overview • Kripke structures as models of computation • CTL, LTL and property patterns • CTL model-checking and counterexample generation • State of the Art Model-Checkers 3 SW/HW Correct? Correctness Artifact properties Model Translation Extraction Abstraction Finite Temporal Model logic Model Yes/No + Checker Counter-example 4 Models: Kripke Structures s 0 req req, s1 Conventional state machines busy • K = (V, S, s0, I , R) • V is a (finite) set of atomic s2 s3 propositions busy • S is a (finite) set of states • s0 S is a start state • I: S 2V is a labelling function that maps each state to the set of propositional variables that hold in it • That is, I(S) is a set of interpretations specifying which propositions are true in each state • R S S is a transition relation 5 Propositional Variables Fixed set of atomic propositions, e.g, {p, q, r} Atomic descriptions of a system “Printer is busy” “There are currently no requested jobs for the printer” “Conveyer belt is stopped” Do not involve time! 6 Modal Logic Extends propositional logic with modalities to qualify propositions • “it is raining” – rain • “it will rain tomorrow” – ☐rain • it is raining in all possible futures • “it might rain tomorrow” – ⃟rain • it is raining in some possible futures Modal logic formulas are interpreted over a collection of possible worlds connected by an accessibility relation Temporal logic is a modal logic that adds temporal modalities: next, always, eventually, and until 7 Computation Tree Logic (CTL) CTL: Branching-time
    [Show full text]
  • Lecture Notes on Computations & Computation Tree Logic
    15-414: Bug Catching: Automated Program Verification Lecture Notes on Computations & Computation Tree Logic Matt Fredrikson Andre´ Platzer Carnegie Mellon University Lecture 16 1 Introduction Linear temporal logic is a very important logic for model checking [Eme90, CGP99, BKL08] but has the downside that its verification algorithms are rather complex. To get a good sense of how model checking works, we, thus, consider the closely related but different(!) Computation Tree Logic (CTL) instead. Both LTL and CTL are common in model checking even if they have different advantages and downsides. The main point about LTL is that its semantics fixes a trace and then talks about temporal properties along that particular trace. CTL instead switches to a new trace every time a temporal operator is used. CTL has the advantage of having a pretty simple model checking algorithm. 2 Kripke Structures Definition 1 (Kripke structure). A Kripke frame (W; y) consists of a set W with a transi- tion relation y ⊆ W ×W where s y t indicates that there is a direct transition from s to t in the Kripke frame (W; y). The elements s 2 W are also called states. A Kripke struc- ture K = (W; y; v) is a Kripke frame (W; y) with a mapping v : W ! Σ ! ftrue; falseg assigning truth-values to all the propositional atoms in all states. The program semantics [[α]] which was defined as a relation of initial and final states in Lecture 3 is an example of a Kripke structure. Definition 2 (Computation structure). A Kripke structure K = (W; y; v) is called a computation structure if W is a finite set of states and every element s 2 W has at least one direct successor t 2 W with s y t.
    [Show full text]
  • Modal Mu-Calculi
    Modal Mu-Calculi Julian Bradfield and Colin Stirling Contents 1 Introduction 2 2 Contextual background 2 2.1 Modal logics in program verification 2 2.2 Precursors to modal mu-calculus 4 2.3 The small model property 5 3 Syntax and semantics of modal mu-calculus 5 3.1 Fixpoints as recursion 6 3.2 Approximating fixpoints and µ as ‘finitely’ 6 3.3 Syntax of Lµ 7 3.4 Semantics of Lµ 8 3.5 Examples 9 3.6 Fixpoint regeneration and the ‘fundamental semantic theorem’ 10 3.7 Modal equation systems 12 4 Expressive power 12 4.1 CTL and friends as fragments of Lµ 13 4.2 Bisimulation and tree model property 13 4.3 Lµ and automata 14 4.4 Lµ and games 15 5 Decidability of satisfiability 16 5.1 The aconjunctive fragment 17 5.2 Towards automata 17 5.3 Alternating parity automata 18 5.4 Automaton normal form 20 6 Complete axiomatization 21 7 Alternation 21 8 Bisimulation invariance 23 8.1 Lµ and MSOL 23 8.2 Multi-dimensional Lµ and Ptime 24 8.3 Bisimulation quantifiers and interpolation 25 9 Generalized mu-calculi 25 9.1 Lµ with past 25 9.2 Least fixpoint logic 26 9.3 Finite variable fixpoint logics 26 9.4 Guarded fragments 27 9.5 Inflationary mu-calculus 27 References 28 Preprint submitted to 15 November 2005 1 Introduction Modal mu-calculus is a logic used extensively in certain areas of computer science, but also of considerable intrinsic mathematical and logical interest. Its defining feature is the addition of inductive definitions to modal logic; thereby it achieves a great increase in expressive power, and an equally great increase in difficulty of understanding.
    [Show full text]
  • Model Checking Is Refinement— Computational Temporal Logic Is Equivalent to Failure Trace Testing
    Model Checking is Refinement— Computational Temporal Logic is Equivalent to Failure Trace Testing by Zhiyu ZHANG A thesis submitted to the Department of Computer Science in conformity with the requirements for the degree of Master of Science Bishop’s Unversity Sherbrooke, Quebec, Canada December 2008 Copyright @ Zhiyu ZHANG, 2008 Abstract The two major systems of formal verification are model checking and algebraic model-based testing. Model checking is based on some form of temporal logic such as linear temporal logic (LTL) or computational temporal logic (CTL). The most powerful and realistic logic being used is CTL, which is capable of expressing most interesting properties of processes such as liveness and safety. Model-based testing is based on some operational semantics of processes (such as traces, failures, or both) and their associated preoders. The most fine-grained preorder beside bisimulation (of theoretical importance only) is the one based on failure traces. We show that these two most powerful variants are equivalent. That is to say, we show that for any failure trace test, there exists a CTL formula equivalent to it (meaning that a system passes the test if and only if the system satisfies the formula and the other way around). When we specify the system, we can use temporal logic formulas such as CTL formulas to express the properties of it. We can also use algebraic method such as labelled transition system or finite state automaton to describe the system’s desired behaviour. If parts of a larger system are specified by these two means at the same time, combining the result of doing model checking and the result of applying model-based testing won’t be ideal, satisfactory and even correct.
    [Show full text]
  • A Probabilistic Temporal Logic with Frequency Operators and Its Model Checking
    A Probabilistic Temporal Logic with Frequency Operators and Its Model Checking Takashi Tomita Shigeki Hagihara Naoki Yonezaki Dept. of Computer Science, Graduate School of Information Science and Engineering, Tokyo Institute of Technology {tomita, hagihara, yonezaki}@fmx.cs.titech.ac.jp Probabilistic Computation Tree Logic (PCTL) and Continuous Stochastic Logic (CSL) are often used to describe specifications of probabilistic properties for discrete time and continuous time, respec- tively. In PCTL and CSL, the possibility of executions satisfying some temporal properties can be quantitatively represented by the probabilistic extension of the path quantifiers in their basic Com- putation Tree Logic (CTL), however, path formulae of them are expressed via the same operators in CTL. For this reason, both of them cannot represent formulae with quantitative temporal proper- ties, such as those of the form “some properties hold to more than 80% of time points (in a certain bounded interval) on the path.” In this paper, we introduce a new temporal operator which expressed the notion of frequency of events, and define probabilistic frequency temporal logic (PFTL) based on CTL∗. As a result, we can easily represent the temporal properties of behavior in probabilistic systems. However, it is difficult to develop a model checker for the full PFTL, due to rich expres- siveness. Accordingly, we develop a model-checking algorithm for the CTL-like fragment of PFTL against finite-state Markov chains, and an approximate model-checking algorithm for the bounded Linear Temporal Logic (LTL) -like fragment of PFTL against countable-state Markov chains. 1 Introduction To analyze probabilistic systems, probabilistic model checking is often used.
    [Show full text]
  • Temporal Representation and Reasoning
    Temporal Representation and Reasoning Michael Fisher∗ Department of Computer Science, University of Liverpool, UK In: F. van Harmelen, B. Porter and V. Lifschitz (eds) Handbook of Knowledge Representation,† c Elsevier 2007 This book is about representing knowledge in all its various forms. Yet, whatever phenomenon we aim to represent, be it natural, computational, or abstract, it is unlikely to be static. The natural world is always decaying or evolving. Thus, computational processes, by their nature, are dynamic, and most abstract notions, if they are to be useful, are likely to incorporate change. Consequently, the notion of representations changing through time is vital. And so, we need a clear way of representing both our temporal basis, and the way in which entities change over time. This is exactly what this chapter is about. We aim to provide the reader with an overview of many of the ways temporal phenomena can be modelled, described, reasoned about, and applied. In this, we will often overlap with other chapters in this collection. Some of these topics we will refer to very little, as they will be covered directly by other chapters, for example temporal action logic [84], situation calculus [185], event calculus [209], spatio-temporal reasoning [74], temporal constraint satisfaction [291], temporal planning [84, 271], and qualitative temporal reasoning [102]. Other topics will be described in this chapter, but overlap with descriptions in other chapters, in particular: • automated reasoning, in Section 3.2 and in [290]; • description logics, in Section 4.6 and in [154]; and • natural language, in Section 4.1 and in [250].
    [Show full text]
  • Satisfiability and Model Checking of CTL∗ with Graded Path Modalities
    Satisfiability and Model Checking of CTL ∗ with Graded Path Modalities Benjamin Aminof 1, Aniello Murano 2, and Sasha Rubin 1 1 TU Vienna, Austria 2 Università degli Studi di Napoli "Federico II", Naples, Italy [email protected] Abstract Graded path modalities count the number of paths satisfying a property, and generalize the exist- ential ( E) and universal (A) path modalities of CTL ∗. The resulting logic is called GCTL ∗. We settle the complexity of satisfiability of GCTL ∗, i.e., 2 ExpTime -Complete , and the complexity of the model checking problem for GCTL ∗, i.e., PSpace -Complete . The lower bounds already hold for CTL ∗, and so, using the automata-theoretic approach we supply the upper bounds. The significance of this work is two-fold: GCTL ∗ is more expressive than CTL ∗ at no extra cost in computational complexity, and GCTL ∗ has all the advantages over GCTL (CTL with graded path modalities) that CTL ∗ has over CTL , e.g., the ability to express fairness. 1 Introduction In formal system specification and design, graded modalities were introduced as a useful extension of the standard existential and universal quantifiers in branching-time modal lo- gics [5, 6, 11, 16, 21]. These modalities allow one to express properties such as “there exist at least n successors satisfying a formula” or “all but n successors satisfy a formula”. The interest in extending logics by graded modalities has been shown to be two-fold: a) typ- ically one gets more expressive logics with very strong forms of counting quantifiers, and b) often the complexity of satisfiability does not increase.
    [Show full text]