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 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.
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
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]
^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. ISBN978-3-540-11576-2.
^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. ISBN0897912527.
References
Clarke, Edmund M. Jr.; Orna Grumberg; Doron A. Peled (1999). Model Checking. Cambridge, Massachusetts, USA: MIT press. ISBN0-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. ISBN0-387-98717-7., chapter 5, Modal μ-calculus, pp. 103–128
André Arnold; Damian Niwiński (2001). Rudiments of μ-Calculus. Elsevier. ISBN978-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.