Modal μ-calculus: Difference between revisions
m →Denotational semantics: typo |
m Disambiguating links to Deadlock (link changed to Deadlock (computer science)) using DisamAssist. |
||
(32 intermediate revisions by 22 users not shown) | |||
Line 1: | Line 1: | ||
{{Short description|Extension of propositional modal logic}} |
|||
In [[theoretical computer science]], the '''modal μ-calculus''' ('''Lμ''', '''L<sub>μ</sub>''', sometimes just '''μ-calculus''', although this can have a more general meaning) is an extension of [[propositional logic|propositional]] [[modal logic]] (with [[Multimodal logic|many modalities]]) by adding |
In [[theoretical computer science]], the '''modal μ-calculus''' ('''Lμ''', '''L<sub>μ</sub>''', sometimes just '''μ-calculus''', although this can have a more general meaning) is an extension of [[propositional logic|propositional]] [[modal logic]] (with [[Multimodal logic|many modalities]]) by adding the [[least fixed point]] operator μ and the [[greatest fixed point]] operator ν, thus a [[fixed-point logic]]. |
||
The (propositional, modal) μ-calculus originates with [[Dana Scott]] and [[Jaco de Bakker]],<ref> |
The (propositional, modal) μ-calculus originates with [[Dana Scott]] and [[Jaco de Bakker]],<ref>{{cite journal |last1=Scott |first1=Dana |author1-link = Dana Scott|last2=Bakker |first2=Jacobus |date=1969 |title=A theory of programs |journal=Unpublished Manuscript}}</ref> and was further developed by [[Dexter Kozen]]<ref name="Kozen1982">{{cite conference|last1=Kozen|first1=Dexter|title=Results on the propositional μ-calculus|conference=ICALP|year=1982|book-title=Automata, Languages and Programming|volume=140|pages=348–359|isbn=978-3-540-11576-2|doi=10.1007/BFb0012782}}</ref> into the version most used nowadays. It is used to describe properties of [[labelled transition system]]s and for [[model checking|verifying]] these properties. Many [[temporal logic]]s can be encoded in the μ-calculus, including [[CTL*]] and its widely used fragments—[[linear temporal logic]] and [[computational tree logic]].<ref>Clarke p.108, Theorem 6; Emerson p. 196</ref> |
||
An algebraic view is to see it as an [[universal algebra|algebra]] of [[monotonic function]]s over a [[complete lattice]], with operators consisting of [[functional composition]] plus the least and greatest fixed point operators; from this viewpoint, the modal μ-calculus is over the lattice of a [[power set algebra]].<ref>Arnold and Niwiński, pp. viii-x and chapter 6</ref> The [[game semantics]] of μ-calculus is related to [[two-player game]]s with [[perfect information]], particularly infinite [[parity game]]s.<ref>Arnold and Niwiński, pp. viii-x and chapter 4</ref> |
An algebraic view is to see it as an [[universal algebra|algebra]] of [[monotonic function]]s over a [[complete lattice]], with operators consisting of [[functional composition]] plus the least and greatest fixed point operators; from this viewpoint, the modal μ-calculus is over the lattice of a [[power set algebra]].<ref>Arnold and Niwiński, pp. viii-x and chapter 6</ref> The [[game semantics]] of μ-calculus is related to [[two-player game]]s with [[perfect information]], particularly infinite [[parity game]]s.<ref>Arnold and Niwiński, pp. viii-x and chapter 4</ref> |
||
== Syntax == |
== Syntax == |
||
Let ''P'' (propositions) and ''A'' (actions) be two finite sets of symbols, and let |
Let ''P'' (propositions) and ''A'' (actions) be two finite sets of symbols, and let Var be a countably infinite set of variables. The set of formulas of (propositional, modal) μ-calculus is defined as follows: |
||
* each proposition and each variable is a formula; |
* each proposition and each variable is a formula; |
||
* if <math>\phi</math> and <math>\psi</math> are formulas, then <math>\phi \wedge \psi</math> is a formula |
* if <math>\phi</math> and <math>\psi</math> are formulas, then <math>\phi \wedge \psi</math> is a formula; |
||
* if <math>\phi</math> is a formula, then <math>\neg \phi</math> is a formula; |
* if <math>\phi</math> is a formula, then <math>\neg \phi</math> is a formula; |
||
* if <math>\phi</math> is a formula and <math>a</math> is an action, then <math>[a] \phi</math> is a formula;(pronounced either: <math>a</math> box <math>\phi </math> or after <math>a</math> necessarily <math>\phi</math>) |
* if <math>\phi</math> is a formula and <math>a</math> is an action, then <math>[a] \phi</math> is a formula; (pronounced either: <math>a</math> box <math>\phi </math> or after <math>a</math> necessarily <math>\phi</math>) |
||
* if <math>\phi</math> is a formula and <math>Z</math> a variable, then <math>\nu Z. \phi</math> is a formula, provided that every free occurrence of <math>Z</math> in <math>\phi</math> occurs positively, i.e. within the scope of an even number of negations. |
* if <math>\phi</math> is a formula and <math>Z</math> a variable, then <math>\nu Z. \phi</math> is a formula, provided that every free occurrence of <math>Z</math> in <math>\phi</math> occurs positively, i.e. within the scope of an even number of negations. |
||
Line 18: | Line 19: | ||
* <math>\phi \lor \psi</math> meaning <math>\neg (\neg \phi \land \neg \psi)</math> |
* <math>\phi \lor \psi</math> meaning <math>\neg (\neg \phi \land \neg \psi)</math> |
||
* <math>\langle a \rangle \phi</math> (pronounced either: <math>a</math> diamond <math>\phi </math> or after <math>a</math> possibly <math>\phi</math>) meaning <math>\neg [a] \neg \phi</math> |
* <math>\langle a \rangle \phi</math> (pronounced either: <math>a</math> diamond <math>\phi </math> or after <math>a</math> possibly <math>\phi</math>) meaning <math>\neg [a] \neg \phi</math> |
||
* <math>\mu Z. \phi</math> means <math>\neg \nu Z. \neg \phi [Z:=\neg Z]</math>, where <math>\phi [Z:=\neg Z]</math> means substituting <math>\neg Z</math> for |
* <math>\mu Z. \phi</math> means <math>\neg \nu Z. \neg \phi [Z:=\neg Z]</math>, where <math>\phi [Z:=\neg Z]</math> means substituting <math>\neg Z</math> for <math>Z</math> in all [[free occurrence]]s of <math>Z</math> in <math>\phi </math>. |
||
The first two formulas are the familiar ones from the classical [[propositional calculus]] and respectively the minimal [[multimodal logic]] '''K'''. |
The first two formulas are the familiar ones from the classical [[propositional calculus]] and respectively the minimal [[multimodal logic]] '''K'''. |
||
The notation <math>\mu Z. \phi</math> (and its dual) are inspired from the [[lambda calculus]]; the intent is to denote the least (and respectively greatest) fixed point of the expression <math>\phi</math> where the "minimization" (and respectively "maximization") are in the variable |
The notation <math>\mu Z. \phi</math> (and its dual) are inspired from the [[lambda calculus]]; the intent is to denote the least (and respectively greatest) fixed point of the expression <math>\phi</math> where the "minimization" (and respectively "maximization") are in the variable <math>Z</math>, much like in lambda calculus <math>\lambda Z. \phi</math> is a function with formula <math>\phi</math> in [[Lambda calculus#Free and bound variables|bound variable]] <math>Z</math>;<ref>Arnold and Niwiński, p. 14</ref> see the denotational semantics below for details. |
||
== Denotational semantics == |
== Denotational semantics == |
||
Models of (propositional) μ-calculus are given as [[labelled transition system]]s <math>(S, R, V)</math> where: |
Models of (propositional) μ-calculus are given as [[labelled transition system]]s <math>(S, R, V)</math> where: |
||
* <math>S</math> is a set of states; |
* <math>S</math> is a set of states; |
||
* <math>R</math> maps to each label <math>a</math> a binary relation on <math>S</math>; |
* <math>R</math> maps to each label <math>a</math> a binary relation on <math>S</math>; |
||
* <math> V : P \ |
* <math> V : P \to 2^S</math>, maps each proposition <math>p \in P</math> to the set of states where the proposition is true. |
||
⚫ | |||
⚫ | |||
* <math>[\![p]\!]_i = V(p)</math>; |
* <math>[\![p]\!]_i = V(p)</math>; |
||
* <math>[\![Z]\!]_i = i(Z)</math>; |
* <math>[\![Z]\!]_i = i(Z)</math>; |
||
Line 37: | Line 40: | ||
* <math>[\![[a] \phi]\!]_i = \{s \in S \mid \forall t \in S, (s, t) \in R_a \rightarrow t \in [\![\phi]\!]_i\}</math>; |
* <math>[\![[a] \phi]\!]_i = \{s \in S \mid \forall t \in S, (s, t) \in R_a \rightarrow t \in [\![\phi]\!]_i\}</math>; |
||
* <math>[\![\nu Z. \phi]\!]_i = \bigcup \{T \subseteq S \mid T \subseteq [\![\phi]\!]_{i[Z := T]}\}</math>, where <math>i[Z := T]</math> maps <math>Z</math> to <math>T</math> while preserving the mappings of <math>i</math> everywhere else. |
* <math>[\![\nu Z. \phi]\!]_i = \bigcup \{T \subseteq S \mid T \subseteq [\![\phi]\!]_{i[Z := T]}\}</math>, where <math>i[Z := T]</math> maps <math>Z</math> to <math>T</math> while preserving the mappings of <math>i</math> everywhere else. |
||
By duality, the interpretation of the other basic formulas is: |
By duality, the interpretation of the other basic formulas is: |
||
* <math>[\![\phi \vee \psi]\!]_i = [\![\phi]\!]_i \cup [\![\psi]\!]_i</math>; |
* <math>[\![\phi \vee \psi]\!]_i = [\![\phi]\!]_i \cup [\![\psi]\!]_i</math>; |
||
* <math>[\![\langle a \rangle \phi]\!]_i = \{s \in S \mid \exists t \in S, (s, t) \in R_a \wedge t \in [\![\phi]\!]_i\}</math>; |
* <math>[\![\langle a \rangle \phi]\!]_i = \{s \in S \mid \exists t \in S, (s, t) \in R_a \wedge t \in [\![\phi]\!]_i\}</math>; |
||
* <math>[\![\mu Z. \phi]\!]_i = \bigcap \{T \subseteq S \mid [\![\phi]\!]_{i[Z := T]} \subseteq T \}</math> |
* <math>[\![\mu Z. \phi]\!]_i = \bigcap \{T \subseteq S \mid [\![\phi]\!]_{i[Z := T]} \subseteq T \}</math> |
||
Less formally, this means that, for a given transition system <math>(S, R, V)</math>: |
Less formally, this means that, for a given transition system <math>(S, R, V)</math>: |
||
* <math>p</math> holds in the set of states <math>V(p)</math>; |
* <math>p</math> holds in the set of states <math>V(p)</math>; |
||
* <math>\phi \wedge \psi</math> holds in every state where <math>\phi</math> and <math>\psi</math> both hold; |
* <math>\phi \wedge \psi</math> holds in every state where <math>\phi</math> and <math>\psi</math> both hold; |
||
Line 47: | Line 54: | ||
* <math>[a] \phi</math> holds in a state <math>s</math> if every <math>a</math>-transition leading out of <math>s</math> leads to a state where <math>\phi</math> holds. |
* <math>[a] \phi</math> holds in a state <math>s</math> if every <math>a</math>-transition leading out of <math>s</math> leads to a state where <math>\phi</math> holds. |
||
* <math>\langle a\rangle \phi</math> holds in a state <math>s</math> if there exists <math>a</math>-transition leading out of <math>s</math> that leads to a state where <math>\phi</math> holds. |
* <math>\langle a\rangle \phi</math> holds in a state <math>s</math> if there exists <math>a</math>-transition leading out of <math>s</math> that leads to a state where <math>\phi</math> holds. |
||
* <math>\nu Z.\phi</math> holds in any state in any set <math>T</math> such that, when the variable <math>Z</math> is set to <math>T</math>, then <math>\phi</math> holds for all of <math>T</math>. (From the [[Knaster–Tarski theorem]] it follows that <math>[\![\nu Z.\phi]\!]_i</math> is the |
* <math>\nu Z.\phi</math> holds in any state in any set <math>T</math> such that, when the variable <math>Z</math> is set to <math>T</math>, then <math>\phi</math> holds for all of <math>T</math>. (From the [[Knaster–Tarski theorem]] it follows that <math>[\![\nu Z.\phi]\!]_i</math> is the [[greatest fixed point]] of <math>T\mapsto[\![\phi]\!]_{i[Z := T]}</math>, and <math>[\![\mu Z. \phi]\!]_i</math> its [[least fixed point]].) |
||
The interpretations of <math>[a] \phi</math> and <math>\langle a\rangle \phi</math> are in fact the "classical" ones from [[Dynamic logic (modal logic)|dynamic logic]]. Additionally, the operator <math>\mu</math> can be interpreted as [[liveness]] ("something good eventually happens") and <math>\nu</math> as [[safety (computer science)|safety]] ("nothing bad ever happens") in [[Leslie Lamport]]'s informal classification.<ref name="Bradfield and Stirling, p. 731">Bradfield and Stirling, p. 731</ref> |
The interpretations of <math>[a] \phi</math> and <math>\langle a\rangle \phi</math> are in fact the "classical" ones from [[Dynamic logic (modal logic)|dynamic logic]]. Additionally, the operator <math>\mu</math> can be interpreted as [[liveness]] ("something good eventually happens") and <math>\nu</math> as [[safety (computer science)|safety]] ("nothing bad ever happens") in [[Leslie Lamport]]'s informal classification.<ref name="Bradfield and Stirling, p. 731">Bradfield and Stirling, p. 731</ref> |
||
=== Examples === |
=== Examples === |
||
* <math>\nu Z.\phi \wedge [a]Z</math> is interpreted as "<math>\phi</math> is true along every ''a''-path".<ref name="Bradfield and Stirling, p. 731"/> |
|||
* <math>\nu Z.\phi \wedge [a]Z</math> is interpreted as "<math>\phi</math> is true along every ''a''-path".<ref name="Bradfield and Stirling, p. 731"/> The idea is that "<math>\phi</math> is true along every ''a''-path" can be defined axiomatically as that (weakest) sentence <math>Z</math> which implies <math>\phi</math> and which remains true after processing any ''a''-label. <ref>Bradfield and Stirling, p. 6</ref> |
|||
* <math>\mu Z.\phi \vee \langle a \rangle Z</math> is interpreted as the existence of a path along ''a''-transitions to a state where <math>\phi</math> holds.<ref name="GrädelKolaitis2007"/> |
* <math>\mu Z.\phi \vee \langle a \rangle Z</math> is interpreted as the existence of a path along ''a''-transitions to a state where <math>\phi</math> holds.<ref name="GrädelKolaitis2007"/> |
||
* The property of a |
* The property of a state being [[Deadlock (computer science)|deadlock]]-free, meaning no path from that state reaches a dead end, is expressed by the formula<ref name="GrädelKolaitis2007">{{cite book|author1=Erich Grädel | author2=Phokion G. Kolaitis | author3=Leonid Libkin|author3-link=Leonid Libkin |author4=Maarten Marx | author5=[[Joel Spencer]] | author6=[[Moshe Y. Vardi]] | author7=Yde Venema | author8=Scott Weinstein | title=Finite Model Theory and Its Applications | url=https://books.google.com/books?id=e6ST-AVC27AC&pg=PA159 | year=2007 | publisher=Springer | isbn=978-3-540-00428-8 | page=159}}</ref> <math display="block">\nu Z.\left (\bigvee_{a\in A}\langle a\rangle\top\wedge \bigwedge_{a\in A}[a]Z \right)</math> |
||
*: <math>\nu Z.(\bigvee_{a\in A}\langle a\rangle\top\wedge \bigwedge_{a\in A}[a]Z)</math> |
|||
==Decision problems== |
==Decision problems== |
||
[[Satisfiability]] of a modal μ-calculus formula is [[EXPTIME-complete]].<ref name="Schneider2004">{{cite book|author=Klaus Schneider|title=Verification of reactive systems: formal methods and algorithms|url=https://books.google.com/books?id=Z92bL1VrD_sC&pg=PA521|year=2004|publisher=Springer|isbn=978-3-540-00296-3|page=521}}</ref> |
[[Satisfiability]] of a modal μ-calculus formula is [[EXPTIME-complete]].<ref name="Schneider2004">{{cite book|author=Klaus Schneider|title=Verification of reactive systems: formal methods and algorithms|url=https://books.google.com/books?id=Z92bL1VrD_sC&pg=PA521|year=2004|publisher=Springer|isbn=978-3-540-00296-3|page=521}}</ref> Like for linear temporal logic,<ref>{{Cite journal|last1=Sistla|first1=A. P.|last2=Clarke|first2=E. M.|date=1985-07-01|title=The Complexity of Propositional Linear Temporal Logics|journal=J. ACM|volume=32|issue=3|pages=733–749|doi=10.1145/3828.3837|issn=0004-5411|doi-access=free}}</ref> the [[model checking]], satisfiability and validity problems of linear modal μ-calculus are [[PSPACE-complete]].<ref>{{Cite book|last=Vardi|first=M. Y.|title=Proceedings of the 15th ACM SIGPLAN-SIGACT symposium on Principles of programming languages - POPL '88 |chapter=A temporal fixpoint calculus |date=1988-01-01|location=New York, NY, USA|publisher=ACM|pages=250–259|doi=10.1145/73560.73582|isbn=0897912527|doi-access=free}}</ref> |
||
== See also == |
== See also == |
||
Line 69: | Line 76: | ||
==References== |
==References== |
||
*{{cite book |
*{{cite book |
||
| last = Clarke |
| last = Clarke |
||
| first = Edmund M. |
| first = Edmund M. Jr. |
||
|author2=Orna Grumberg |author3=Doron A. Peled |
|author2=Orna Grumberg |author3=Doron A. Peled |
||
| title = Model Checking |
| title = Model Checking |
||
Line 88: | Line 95: | ||
}}, chapter 5, Modal μ-calculus, pp. 103–128 |
}}, chapter 5, Modal μ-calculus, pp. 103–128 |
||
* {{cite book|author1=André Arnold|author2=Damian Niwiński|title=Rudiments of μ-Calculus|year=2001|publisher=Elsevier|isbn=978-0-444-50620-7}}, chapter 6, The μ-calculus over powerset algebras, pp. 141–153 is about the modal μ-calculus |
* {{cite book|author1=André Arnold|author2=Damian Niwiński|title=Rudiments of μ-Calculus|year=2001|publisher=Elsevier|isbn=978-0-444-50620-7}}, chapter 6, The μ-calculus over powerset algebras, pp. 141–153 is about the modal μ-calculus |
||
* Yde Venema (2008) [http://philo.ruc.edu.cn/logic/reading/Yde/mu0612.pdf Lectures on the Modal μ-calculus]; was presented at The 18th European Summer School in Logic, Language and Information |
* Yde Venema (2008) [https://web.archive.org/web/20160305061922/http://philo.ruc.edu.cn/logic/reading/Yde/mu0612.pdf Lectures on the Modal μ-calculus]; was presented at The 18th European Summer School in Logic, Language and Information |
||
*{{cite book |
*{{cite book |
||
|author1=Bradfield, Julian |author2=Stirling, Colin |
|author1=Bradfield, Julian |author2=Stirling, Colin |
||
| |
|name-list-style=amp | year = 2006 |
||
| chapter = Modal mu-calculi |
| chapter = Modal mu-calculi |
||
| title = The Handbook of Modal Logic |
| title = The Handbook of Modal Logic |
||
|editor1=P. Blackburn |editor2=J. van Benthem |editor3=F. Wolter | publisher = [[Elsevier]] |
|editor1=P. Blackburn |editor2=J. van Benthem |editor3=F. Wolter | publisher = [[Elsevier]] |
||
| pages = 721–756 |
| pages = 721–756 |
||
| url = http://homepages.inf.ed.ac.uk/jcb/Research/pubs.html#mlh-chapter |
| chapter-url = http://homepages.inf.ed.ac.uk/jcb/Research/pubs.html#mlh-chapter |
||
}} |
}} |
||
*{{cite conference |
*{{cite conference |
||
| first = E. Allen |
| first = E. Allen |
||
| last = Emerson |
| last = Emerson |
||
|author-link = E. Allen Emerson |
|||
| title = Model Checking and the Mu-calculus |
| title = Model Checking and the Mu-calculus |
||
| |
| book-title = Descriptive Complexity and Finite Models |
||
| year = 1996 |
| year = 1996 |
||
| pages = 185–214 |
| pages = 185–214 |
||
Line 117: | Line 125: | ||
| pages = 333–354 |
| pages = 333–354 |
||
| doi = 10.1016/0304-3975(82)90125-6 |
| doi = 10.1016/0304-3975(82)90125-6 |
||
| doi-access= |
|||
}} |
}} |
||
Line 123: | Line 132: | ||
{{DEFAULTSORT:Modal mu-calculus}} |
{{DEFAULTSORT:Modal mu-calculus}} |
||
[[Category:Modal logic]] |
[[Category:Modal logic|μ-calculus]] |
||
[[Category:Model checking]] |
[[Category:Model checking]] |
Latest revision as of 21:25, 20 August 2024
In theoretical computer science, the modal μ-calculus (Lμ, Lμ, sometimes just μ-calculus, although this can have a more general meaning) is an extension of propositional modal logic (with many modalities) by adding the least fixed point operator μ and the greatest fixed point operator ν, thus a fixed-point logic.
The (propositional, modal) μ-calculus originates with Dana Scott and Jaco de Bakker,[1] and was further developed by Dexter Kozen[2] into the version most used nowadays. It is used to describe properties of labelled transition systems and for verifying these properties. Many temporal logics can be encoded in the μ-calculus, including CTL* and its widely used fragments—linear temporal logic and computational tree logic.[3]
An algebraic view is to see it as an algebra of monotonic functions over a complete lattice, with operators consisting of functional composition plus the least and greatest fixed point operators; from this viewpoint, the modal μ-calculus is over the lattice of a power set algebra.[4] The game semantics of μ-calculus is related to two-player games with perfect information, particularly infinite parity games.[5]
Syntax
[edit]Let P (propositions) and A (actions) be two finite sets of symbols, and let Var be a countably infinite set of variables. The set of formulas of (propositional, modal) μ-calculus is defined as follows:
- each proposition and each variable is a formula;
- if and are formulas, then is a formula;
- if is a formula, then is a formula;
- if is a formula and is an action, then is a formula; (pronounced either: box or after necessarily )
- if is a formula and a variable, then is a formula, provided that every free occurrence of in occurs positively, i.e. within the scope of an even number of negations.
(The notions of free and bound variables are as usual, where is the only binding operator.)
Given the above definitions, we can enrich the syntax with:
- meaning
- (pronounced either: diamond or after possibly ) meaning
- means , where means substituting for in all free occurrences of in .
The first two formulas are the familiar ones from the classical propositional calculus and respectively the minimal multimodal logic K.
The notation (and its dual) are inspired from the lambda calculus; the intent is to denote the least (and respectively greatest) fixed point of the expression where the "minimization" (and respectively "maximization") are in the variable , much like in lambda calculus is a function with formula in bound variable ;[6] see the denotational semantics below for details.
Denotational semantics
[edit]Models of (propositional) μ-calculus are given as labelled transition systems where:
- is a set of states;
- maps to each label a binary relation on ;
- , maps each proposition to the set of states where the proposition is true.
Given a labelled transition system and an interpretation of the variables of the -calculus, , is the function defined by the following rules:
- ;
- ;
- ;
- ;
- ;
- , where maps to while preserving the mappings of everywhere else.
By duality, the interpretation of the other basic formulas is:
- ;
- ;
Less formally, this means that, for a given transition system :
- holds in the set of states ;
- holds in every state where and both hold;
- holds in every state where does not hold.
- holds in a state if every -transition leading out of leads to a state where holds.
- holds in a state if there exists -transition leading out of that leads to a state where holds.
- holds in any state in any set such that, when the variable is set to , then holds for all of . (From the Knaster–Tarski theorem it follows that is the greatest fixed point of , and its least fixed point.)
The interpretations of and are in fact the "classical" ones from dynamic logic. Additionally, the operator can be interpreted as liveness ("something good eventually happens") and as safety ("nothing bad ever happens") in Leslie Lamport's informal classification.[7]
Examples
[edit]- is interpreted as " is true along every a-path".[7] The idea is that " is true along every a-path" can be defined axiomatically as that (weakest) sentence which implies and which remains true after processing any a-label. [8]
- is interpreted as the existence of a path along a-transitions to a state where holds.[9]
- The property of a state being deadlock-free, meaning no path from that state reaches a dead end, is expressed by the formula[9]
Decision problems
[edit]Satisfiability of a modal μ-calculus formula is EXPTIME-complete.[10] Like for linear temporal logic,[11] the model checking, satisfiability and validity problems of linear modal μ-calculus are PSPACE-complete.[12]
See also
[edit]Notes
[edit]- ^ Scott, Dana; Bakker, Jacobus (1969). "A theory of programs". Unpublished Manuscript.
- ^ Kozen, Dexter (1982). "Results on the propositional μ-calculus". Automata, Languages and Programming. ICALP. Vol. 140. pp. 348–359. doi:10.1007/BFb0012782. ISBN 978-3-540-11576-2.
- ^ Clarke p.108, Theorem 6; Emerson p. 196
- ^ Arnold and Niwiński, pp. viii-x and chapter 6
- ^ Arnold and Niwiński, pp. viii-x and chapter 4
- ^ Arnold and Niwiński, p. 14
- ^ a b Bradfield and Stirling, p. 731
- ^ Bradfield and Stirling, p. 6
- ^ a b Erich Grädel; Phokion G. Kolaitis; Leonid Libkin; Maarten Marx; Joel Spencer; Moshe Y. Vardi; Yde Venema; Scott Weinstein (2007). Finite Model Theory and Its Applications. Springer. p. 159. ISBN 978-3-540-00428-8.
- ^ Klaus Schneider (2004). Verification of reactive systems: formal methods and algorithms. Springer. p. 521. ISBN 978-3-540-00296-3.
- ^ Sistla, A. P.; Clarke, E. M. (1985-07-01). "The Complexity of Propositional Linear Temporal Logics". J. ACM. 32 (3): 733–749. doi:10.1145/3828.3837. ISSN 0004-5411.
- ^ Vardi, M. Y. (1988-01-01). "A temporal fixpoint calculus". Proceedings of the 15th ACM SIGPLAN-SIGACT symposium on Principles of programming languages - POPL '88. New York, NY, USA: ACM. pp. 250–259. doi:10.1145/73560.73582. ISBN 0897912527.
References
[edit]- Clarke, Edmund M. Jr.; Orna Grumberg; Doron A. Peled (1999). Model Checking. Cambridge, Massachusetts, USA: MIT press. ISBN 0-262-03270-8., chapter 7, Model checking for the μ-calculus, pp. 97–108
- Stirling, Colin. (2001). Modal and Temporal Properties of Processes. New York, Berlin, Heidelberg: Springer Verlag. ISBN 0-387-98717-7., chapter 5, Modal μ-calculus, pp. 103–128
- André Arnold; Damian Niwiński (2001). Rudiments of μ-Calculus. Elsevier. ISBN 978-0-444-50620-7., chapter 6, The μ-calculus over powerset algebras, pp. 141–153 is about the modal μ-calculus
- Yde Venema (2008) Lectures on the Modal μ-calculus; was presented at The 18th European Summer School in Logic, Language and Information
- Bradfield, Julian & Stirling, Colin (2006). "Modal mu-calculi". In P. Blackburn; J. van Benthem & F. Wolter (eds.). The Handbook of Modal Logic. Elsevier. pp. 721–756.
- Emerson, E. Allen (1996). "Model Checking and the Mu-calculus". Descriptive Complexity and Finite Models. American Mathematical Society. pp. 185–214. ISBN 0-8218-0517-7.
- Kozen, Dexter (1983). "Results on the Propositional μ-Calculus". Theoretical Computer Science. 27 (3): 333–354. doi:10.1016/0304-3975(82)90125-6.
External links
[edit]- Sophie Pinchinat, Logic, Automata & Games video recording of a lecture at ANU Logic Summer School '09