Abstract
A classical method for model-checking timed properties—such as those expressed using timed extensions of temporal logic—is to rely on the use of observers. In this context, a major problem is to prove the correctness of observers. Essentially, this boils down to proving that: (1) every trace that contradicts a property can be detected by the observer; but also that (2) the observer is innocuous, meaning that it cannot interfere with the system under observation. In this paper, we describe a method for automatically testing the correctness of realtime observers. This method is obtained by automating an approach often referred to as visual verification, in which the correctness of a system is performed by inspecting a graphical representation of its state space. Our approach has been implemented on the tool Tina, a model-checking toolbox for Time Petri Net.
This work was partly supported by the ITEA2 Project OpenETCS.
You have full access to this open access chapter, Download conference paper PDF
Similar content being viewed by others
Keywords
These keywords were added by machine and not by the authors. This process is experimental and the keywords may be updated as the learning algorithm improves.
1 Introduction
A classical method for model-checking timed behavioral properties—such as those expressed using timed extensions of temporal logic—is to rely on the use of observers. In this approach, we check that a given property, P, is valid for a system S by checking the behavior of the system composed with an observer for the property. That is, for every property P of interest, we need a pair \((\textsf {\small Obs}_P, \phi _{P})\) of a system (the observer) and a formula. Then property P is valid if and only if the composition of S with \(\textsf {\small Obs}_P\), denoted (\(\textsf {\small S}\varvec{\,||\,}\textsf {\small Obs}_P\)), satisfies \(\phi _{P}\). This approach is useful when the properties are complex, for instance when they include realtime constraints or involve arithmetic expressions on variables. Another advantage is that we can often reduce the initial verification problem to a much simpler model-checking problem, for example when \(\phi _{P}\) is a simple reachability property.
In this context, a major problem is to prove the correctness of observers. Essentially, this boils down to proving that every trace that contradicts a property can be detected. But this also involves proving that an observer will never block the execution of a valid trace; we say that it is innocuous or non-intrusive. In other words, we need to assure that the “measurements” performed by the observer can be made without affecting the system.
In the present work, we propose to use a model-checking tool chain in order to check the correctness of observers. We consider observers related to linear time properties obtained by extending the pattern specification language of Dwyer et al. [7] with hard, realtime constraints. In this paper, we take the example of the pattern “Present a after b within \([d_1, d_2[\)”, meaning that event a must occur after \(d_1\) units of time (u.t.) of the first occurrence of b, if any, but not later than \(d_2\). Our approach can be used to prove both the soundness and correctness of an observer when we fix the values of the timing constraints (the values of \(d_1\) and \(d_2\) in this particular case).
Our method is not enough, by itself, to prove the correctness of a verification tool. Indeed, to be totally trustworthy, this will require the use of more heavy-duty software verification methods, such as interactive theorem proving. Nonetheless our method is complementary to these approaches. In particular it can be used to debug new or optimized definitions of an observer for a given property before engaging in a more complex formal proof of its correctness.
Our method is obtained by automating an approach often referred to as visual verification, in which the correctness of a system is performed by inspecting a graphical representation of its state space. Instead of visual inspection, we check a set of branching time (modal \(\mu \)-calculus) properties on the discrete time state space of a system. These formulas are derived automatically from a definition of the pattern expressed as a first-order formula over timed traces. The gist of this method is that, in a discrete time setting, first-order formulas over timed traces can be expressed, interchangeably, as regular expressions, LTL formulas or modal \(\mu \)-calculus formulas.
This approach has been implemented on the tool Tina [4], a model-checking toolbox for Time Petri Net [11] (TPN). This implementation takes advantage of several components of Tina: state space exploration algorithms with a discrete time semantics (using the option -F1 of Tina); model-checkers for LTL and for modal \(\mu \)-calculus, called selt and muse respectively; a new notion of verification probes recently added to Fiacre [3, 5], one of the input specification language of Tina. While model checkers are used to replace visual verification, probes are used to ensure innocuousness of the observers.
Outline and Contributions. The rest of the paper is organized as follows. In Sect. 2, we give a brief definition of Fiacre and the use of probes and observers in this language. In Sect. 3, we introduce the technical notations necessary to define the semantics of patterns and timed traces and focus on an example of timed patterns. Before concluding, we describe the graphical verification method and show how to use a model-checker to automate the verification processFootnote 1.
The theory and technologies underlying our verification method are not new: model-checking algorithms, semantics of realtime patterns, connection between path properties and modal logics, \(\ldots \) Nonetheless, we propose a novel way to combine these techniques in order to check the implementation of observers and in order to replace traditional “visual” verification methods that are prone to human errors.
Our paper also makes some contributions at the technical level. In particular, this is the first paper that documents the notion of probe, that was only recently added to Fiacre. We believe that our (language-level) notion of probes is interesting in its own right and could be adopted in other specification languages.
2 The Fiacre Language
We consider systems modeled using the specification language Fiacre [3, 5]. (Both the system and the observers are expressed in the same language.) Fiacre is a high-level, formal specification language designed to represent both the behavioral and timing aspects of reactive systems.
Fiacre programs are stratified in two main notions: processes, which are well-suited for modeling structured activities, and components, which describes a system as a composition of processes. Components can be hierarchically composed. We give in Fig. 1 a simple example of Fiacre specification for a computer mouse button capable of emitting a double-click event. The behavior, in this case, is to emit the event double if there are more than two click events in strictly less than one unit of time (u.t.).
Processes. A process is defined by a set of parameters and control states, each associated with a set of complex transitions (introduced by the keyword from). The initial state of a process is the state corresponding to the first from declaration.
Complex transitions are expressions that declare how variables are updated and which transitions may fire. They are built from deterministic constructs available in classical programming languages (assignments, conditionals, sequential composition, \(\ldots \)); non-deterministic constructs (such as external choice, with the select operator); communication on ports; and jump to a state (with the to or loop operators).
For example, in Fig. 1, we declare a process named Push with four communication ports (click to delay) and one local boolean variable, dbl. Ports may send and receive typed data. The port type none means that no data is exchanged; these ports simply act as synchronization events. Regarding complex transitions, the expression related to state s1 of Push, for instance, declares two possible transitions from s1: (1) on a click event, set dbl to true and stay in state s1; and (2) on a delay event, change to state s2.
Components. A component is built from the parallel composition of processes and/or other components, expressed with the operator \({\small {\mathbf {\mathsf{{par}}}}} \, \textsf {\small P}_{0} \varvec{\,||\,}\dots \varvec{\,||\,}\textsf {\small P}_{n}\, {\small {\mathbf {\mathsf{{end}}}}}\). In a composition, processes can interact both through synchronization (message-passing) and access to shared variables (shared memory).
Components are the unit for process instantiation and for declaring ports and shared variables. The syntax of components allows to associate timing constraints with communications and to define priorities between communication events. The ability to express directly timing constraints in programs is a distinguishing feature of Fiacre. For example, in the declaration of component Mouse (see Fig. 1), the port statement declares a local event delay and asserts that a transition from s1 to s2 should take exactly one unit of time. (Time passes at the same rate for all the processes.) Additionally, the priority statement asserts that a transition on event click cannot occur if a transition on delay is also possible.
Probes and Observers. The Fiacre language has been extended, recently, to allow the definition of observers, which are a distinguished category of sub-programs that interact with other Fiacre components only through the use of probes. A probe is used to observe modifications in the system without interfering with it; probes react to the occurrence of an event without engaging in it.
A typical probe declaration is of the form path/obs, where obs denotes the observable and path defines its context, that is a path to the component (or process) instance where obs is defined (see for example http://www.laas.fr/fiacre/properties.html). In our setting, observable events are instantaneous actions involved in the evolution of the system: it can be a synchronization over a port p (denoted event p); a process that enters the state s (denoted state s); or an expression including shared variables, say exp, that changes value (denoted value exp). For instance, in the case of the Mouse component of Fig. 1, a probe triggered when the (only instance of) process Push is in state s2 would have the form (Mouse/1/state s2).
The use of probes greatly simplifies the proof of innocuousness of an observer. In particular, with probes, an observer can only influence a system by “blocking the evolution of time”, that is by performing an infinite sequence of actions in finite time. Therefore, proving that an observer is innocuous amounts to proving that it has no Zeno behaviors, which is always possible when a system is bounded.
An observer is a Fiacre component where ports are associated to probes (using the keyword is); ports associated with a probe have the reserved type sync. We give a naive example of observer in Fig. 2, where the component Obs monitors synchronizations on the event click. In this example, the process neverTwice will reach the state error if its probe parameter, a, is triggered more than once.
In the remainder of the text, we use the notation (\(\textsf {\small Mouse} \varvec{\,||\,}\textsf {\small Obs}\)) to denote the program obtained by concatenating the declaration of these two components (i.e. the code from Fig. 1 with the code from Fig. 2). As a consequence, we are able to detect if the system can emit two single click events just by checking if the process neverTwice can reach the state error in (\(\textsf {\small Mouse} \varvec{\,||\,}\textsf {\small Obs}\)).
3 Timed Traces and First-Order Formulas Over Traces
The semantics of Fiacre (and the properties we want to check) are based on a notion of timed traces, which are sequences mixing events and time delays. In this context, a “realtime property” can be defined as a set of timed traces, which define timing and behavioral constraints on the acceptable execution of a system. In this work, we consider properties derived from realtime patterns, that can be expressed using first-order formulas over timed traces.
Timed Traces. In our context, observable events are: communication on a port; the change of state of a process; and the change of value of a variable. We use a dense time model, meaning that we consider rational time delays and work both with strict and non-strict time bounds. Hence a timed trace is a (possibly infinite) sequence of events \(a, b,\ldots \) and durations \(\delta \in \mathbb {Q}^{+}\):
Given a finite trace \(\sigma \) and a—possibly infinite—trace \(\sigma '\), we denote \(\sigma \sigma '\) the concatenation of \(\sigma \) and \(\sigma '\). We will also use the expression \(\varDelta (\sigma )\) to denote the duration (time length) of a trace \(\sigma \), that is the sum of the individual delays in \(\sigma \). The semantics of a system expressed with Fiacre, say S, can be defined as a set \([\![{\textsf {\small S}}]\!]\) of timed traces. We use the notation \(\sigma \;\models \;\textsf {\small S}\) when the trace \(\sigma \) is in the set \([\![{\textsf {\small S}}]\!]\). The semantics of a property (timed pattern) will be expressed as the set of all timed traces where the pattern holds. We say that a system S satisfies a timed requirement P if \([\![{\textsf {\small S}}]\!] \subseteq [\![{\textsf {\small P}}]\!]\).
Realtime Properties and Their Semantics. We propose to define properties using First-Order Formulas over Timed Traces (FOTT). A FOTT formula \(\varPhi ({\varvec{x}})\), with free variables \({\varvec{x}} = (x_1, \dots , x_n)\), is a first-order logic formula over traces with equality between traces (\(\sigma = \sigma '\)), comparison between a duration and an interval (\(\varDelta (\sigma ) \in I\)) and concatenation \((\sigma = \sigma _1 \, \sigma _2\)).
For instance, when referring to a timed trace \(\sigma \) and an event a, the following formula is a tautology if the event a does not occur in \(\sigma \):
Likewise, we can define the “scope” \(\sigma \) after b—that determines the part of a trace \(\sigma \) located after the first occurrence of b—as the trace \(\sigma '\) denoted by the first-order formula: \(\exists x, y \ .\ (\sigma = x\, y) \wedge (y = b\, \sigma ') \wedge \left( b \notin x \right) \).
The semantics of a formula \(\varPhi (x_1, \dots , x_n)\) is a set of valuation functions \(\varsigma \) associating a trace \(\sigma _i = \varsigma (x_i)\) to each of the variables \(x_i\) with \(i \in 1..n\), also denoted \([ x_i \mapsto \sigma _i ]_{i \in 1..n}\). The semantics of \(\varPhi \) can be defined inductively as follows:
data:image/s3,"s3://crabby-images/4ec42/4ec4252d229221d1203bc6b9f41bc5b4ea5deb13" alt=""
With these definitions, a regular set of timed traces is the set of traces “solutions” of an existential FOTT formula with a single free variable, \(\varPhi (x)\); that is the set of traces \(\sigma \) such that the valuation \([x \mapsto \sigma ]\) is in \([\![{\varPhi (x)}]\!]\).
In this paper, we will mainly restrict ourselves to the special case of timed traces where events occur at integer dates; i.e. we restrict delays \(\delta \) to be in \(\mathbb {N}\) rather than in \(\mathbb {Q}^{+}\). These traces can be generated using a “discrete time” abstraction of the models, where special transitions (labeled with t) are used to model the flow of time. Label t stands for the “tick” of the logical clock.
The discrete time semantics will be enough to prove all the properties needed in our study. Indeed, when a model contains only “closed timing constraints” (of the kind \([d_1, d_2]\) or \([d_1, \infty [\)), the discrete time semantics is enough to check reachability properties.
With discrete time, a delay \(\delta \) can be replaced by sequences of \(\delta \) t’s, and therefore a finite timed trace can be simply interpreted as a word. In the remainder, we also consider a special symbol, z, that stands for internal actions of the system. Hence it is possible to interpret the semantics of (discrete) FOTT specification as a language over the alphabet \(A = \{\textsf {\small z}, \textsf {\small t}, \textsf {\small a}, \textsf {\small b},\ldots \}\). Actually, in the discrete case, we can show that a regular set of timed traces is also a regular language. For example, the semantics of the formula \(\exists y, z, w \ .\ \left( (x = y \, z) \wedge (z = a \, w) \right) \) is the regular language corresponding to the expression \(A\mathclose {\overset{*}{\ }}\cdot \textsf {\small a} \cdot A\mathclose {\overset{*}{\ }}\).
This connection between different type of logics is at the core of our approach. Our method could be applied to more high-level property languages, such as timed extension of temporal logic [10], but would require a more complex encoding into LTL when modalities can be nested.
Our Running Example: The Present Pattern. Users of Fiacre have access to a catalog of specification patterns based on a hierarchical classification borrowed from Dwyer [7]. Patterns are built from five basic categories—existence, absence, universality, response and precedence—and can be composed using logical connectives. In each category, generic patterns may be specialized using scope modifiers—such as before, after, between—that limit the range of the execution trace over which the pattern must hold. Finally, timed patterns are obtained using one of two possible kinds of timing modifiers that limit the possible dates of events referred in the pattern: within I—used to constrain the delay between two given events to be in the time interval I—and lasting d—used to constrain the length of time during which a given condition holds (without interruption) to be greater than d.
Due to limited space, we study only one example of timed pattern, namely Present a after b within \([d_1, d_2[\). A complete catalog is available in [1]. This is a simple example of existence patterns. Existence patterns are used to express that, in every trace of the system, some events must occur. This pattern holds for traces such that the event a occurs at a date \(t_0\) after the first occurrence of b with \(t_0 \in [d_1, d_2[\). The property is also satisfied if b never holds. Hence traces \(\sigma \) that satisfy this pattern are models of the existential FOTT formula:
data:image/s3,"s3://crabby-images/d4649/d4649d55cf7626e2096bb154669fdaddf4744eec" alt="figure a"
With the discrete semantics, formula \(\mathrm {Pres}(x)\) matches exactly the words of the form \(w_1 \, \textsf {\small b} \, w_2 \, \textsf {\small a} \, w_3\) where \(w_1\) contains no occurrences of b and \(w_2\) contains exactly k occurrences of t with \(k \in [d_1, d_2[\). (This is a regular language.) We show in the next section how to (semi-)automatically generate the regular expression corresponding to such FOTT formulas.
We give an example of observer associated to this pattern in Listing 1.1. This observer is composed of one process that monitors the system through the ports a and b (that should be instantiated with the relevant probes). The process is initially in state idle and moves to start when b is triggered. When in state start for \(d_1\) unit of time, the observer moves to state watch (this is the meaning of the wait operator). The select operator is a non-deterministic choice, with unless coding priorities. Hence, in state watch, the observer moves to stop if an a occurs, unless a duration equals to \((d_2-d_1)\) elapses, in which case it moves to the state error. As a consequence, the pattern is false whenever the probe (Present/state error) is reachable. Hence the formula associated to the pattern is \(\phi _P \overset{{{\tiny \mathrm{def}}}}{=} \textsf {\small [] - (Present/state error)}\).
To prove that an observer Obs for the pattern P is correct, we need to prove that, for every system S, the program (\(\textsf {\small S} \varvec{\,||\,}\textsf {\small Obs}\)) satisfies the formula \(\phi _{P}\) if and only if \([\![{\textsf {\small S}}]\!] \subseteq [\![{\textsf {\small P}}]\!]\). In [1], we have defined a mathematical framework to formally prove these kind of properties, but this framework relies on manual proofs and is not supported by any tooling. Efforts are also under way to completely mechanize these proofs using the Coq proof assistant [8]. Nonetheless, formal proofs of correctness can be quite tedious. Therefore, to detect possible problems with an observer early on (that is, before spending a lot of efforts doing a formal proof of correctness) we also rely on a “visual” verification method, that is akin to debugging our observers.
In the next section, we show how to apply the visual verification approach on our running example. One of the objectives of our work is to replace this visual verification step with a more formal approach. This is done in Sect. 5.
4 Visual Verification of Observers
In the remainder of this section, we describe the visual verification method using the particular case of the pattern Present a after b within [4, 5[; we assume that Obs is the observer Present defined in Listing 1.1, that \(d_1 = 4\) and that \(d_2 = 5\).
To prove that the observer Present is correct, we need to prove, for every system S, the equivalence between two facts: (1) the state (Present/state error) is not reachable in the program (\(\textsf {\small S} \varvec{\,||\,}\textsf {\small Present[a, b]}\)); and (2) the traces of S are valid for the property Pres, i.e. \([\![{\textsf {\small S}}]\!] \subseteq [\![{\mathrm {Pres}}]\!]\).
The first step is to get rid of the universal quantification on all possible systems, S, that is introduced by our definition of correctness. The idea is to check the observer on a particular Fiacre program—called Universal—that can generate all possible combinations of delays and events a, b and z. We give an example of universal process in Listing 1.2. The process Universal has only one state and three possible transitions. Each transition changes the value of a shared integer variable, x. The first and second transitions of Universal can be fired without time constraints. In our context, the probe a will be triggered to the event “setting x to 1” and b to “setting x to 2”. The third transition resets the value of x to 0 immediately and corresponds to the internal event z.
data:image/s3,"s3://crabby-images/fa179/fa1794c315d7d1a0580d7b8d25064608aa518cdc" alt="figure b"
We can now use our verification toolchain to generate the state graph for the program (\(\textsf {\small Universal} \varvec{\,||\,}\textsf {\small Present}\)) using a discrete time exploration construction. This can be obtained using the flag –F1 in Tina (it is possible to generate a state graph with many different abstractions with Tina, including dense time models).
The resulting graph is displayed in Fig. 3. This state graph has been generated and printed using the tool nd, which is also part of the Tina toolset; nd is an editor and animator for extended Time Petri Nets that can export nets and state graphs in several, machine readable formats. This graph has only 26 states and can therefore be easily managed manually. The main factor commanding the number of states is the value of the timing constraints used in the pattern; in our observations, all the generated state graphs were of manageable size.
The transitions in the state graph are also quite straightforward: we find the visible and internal transitions as before, labeled with a, b, z and t. For ease of reading, we have also changed the labels of internal transitions in the observer Present. For instance, the transition from state 2 to 3 corresponds to the observer entering the state start; likewise for the transitions labeled with watch, stop and error. The states where the observer is in state error (the states that contradict the property \(\phi _P \overset{{{\tiny \mathrm{def}}}}{=} \textsf {\small [] - (\texttt {Present}/\texttt {state\,error})}\)) are \({ Errors } = \{20, 22, 23\}\).
We can already debug the pattern Present a after b within [4, 5[ by visually inspecting the state graph.
For soundness, we need to check that, when the pattern is not satisfied—for traces \(\sigma \) that do not satisfy formula \(\mathrm {Pres}\)—then the observer will detect a problem (observer Present eventually reaches a state in the set Errors).
For innocuousness we need to check that, from any state, it is always possible to reach a state where event a (respectively b and t) can fire. Indeed, this means that the observer cannot selectively remove the observation of a particular sequence of external transitions or the passing of time.
This graphical verification method has some drawbacks. As such, it relies on a discrete time model and only works for fixed values of the timing parameters (we have to fix the value of \(d_1\) and \(d_2\)). Nonetheless, it is usually enough to catch many errors in the observer before we try to prove the observer correct more formally.
5 Automating the Visual Verification Method
A problem with the previous approach is that it essentially relies on an informal inspection (and on human interaction). We show how to solve this problem by replacing the visual inspection of the state graph by the verification of modal \(\mu \)-calculus formulas. (the Tina toolset includes a model-checker for the \(\mu \)-calculus called muse.) The general idea rests on the fact that we can interpret the state graph as a finite state automaton and (some) sets of traces as regular languages. This analogy is generally quite useful when dealing with model-checking problems. We start by defining some useful notations.
Label Expressions are boolean expressions denoting a set of (transition) labels. For instance, \(A_\text {ext} = (\textsf {\small a} \vee \textsf {\small b})\) denotes the external transitions, while the expression -( a \(\vee \) b \(\vee \) t ) is only matched by the silent transition label. We will also use the expression \(\top \) to denote the disjunction of all possible labels, e.g. \(\top = \textsf {\small (-b)} \vee \textsf {\small b}\). The model checker muse allows the definition of label expressions using the same syntax.
Regular (Path) Expressions. In the following, we consider regular expressions built from label expressions. For example, the regular expression \(\textsf {\small t} \cdot \textsf {\small (-t)}\mathclose {\overset{*}{\ }}\) denotes traces of duration 1 with no events occurring at time 0.
We remark that it is possible to define the set of (discrete) traces where the FOTT formula Pres holds using the union of two regular languages: (1) the traces where b never occurs, \(\textsf {\small (-b)}\mathclose {\overset{*}{\ }}\); and (2) the traces where there is an a four units of time after the first b. The latter corresponds to the regular expression \((x = y \, \textsf {\small b} \, z \, \textsf {\small a}\, w) \wedge (\textsf {\small b} \notin y) \wedge (\varDelta (z) \in [4,5[\))
By construction, the regular language associated to \(R_1 \vee R_2\) is exactly the set of finite traces matching (the discrete semantics) of Pres. In the most general case, a regular expression can always be automatically generated from an existential FOTT formula when the time constraints of delay expressions are fixed (the intervals I in the occurrences of (\(\varDelta (x) \in I\))).
The next step is to check that the observer agrees with every trace conforming to \(R_2\). For this we simply need to check that, starting from the initial state of (\(\textsf {\small Universal} \varvec{\,||\,}\textsf {\small Present}\)), it is not possible to reach a state in the set Errors by following a sequence of transitions labeled by a word in \(R_2\).
This is a simple instance of a language inclusion problem between finite state automata. More precisely, if \( Present \) is the set of states visited when accepting the traces in \(R_1 \vee R_2\), we need to check that \( Errors \) is included in the complement of the set Present (denoted \(\overline{ Present }\)). In our example of Fig. 3, we have that \(\overline{ Present }= \{17, 20, 22, 23\}\), and therefore \( Errors \subseteq \overline{ Present }\).
This automata-based approach has still some drawbacks. This is what will motivate our use of a branching time logic in the next section. In particular, this method is not enough to check the soundness or the innocuousness of the observer. For innocuousness, we need to check that every event may always eventually happen. Concerning soundness, we need to prove that \( Errors \supseteq \overline{ Present }\); which is false in our case. The problem lies in the treatment of time divergence (and of fairness), as can be seen from one of the counter-example produced when we use our LTL model-checker to check the soundness property, namely: b.start.z.t.t.t.t.watch.t.t. \(\cdots \) (ending with a cycle of t transitions). This is an example where the error transition is continuously enabled but never fired.
Branching Time Specification. We show how to interpret regular expressions over traces using a modal logic. In this case, the target logic is a modal \(\mu \)-calculus with operators for forward and backward traversal of a state graph . (Many temporal logics can be encoded in the \(\mu \)-calculus, including CTL\(\mathclose {\overset{*}{\ }}\)). In this context, the semantics of a formula \(\psi \) over a Kripke structure (a state graph) is the set of states where \(\psi \) holds.
The basic modalities in the logic are \({\texttt {<}}A{\texttt {>}}\psi \) and \(\psi {\texttt {<}}A{\texttt {>}}\), where A is a label expression. A state s is in \({\texttt {<}}A{\texttt {>}}\psi \) if and only if there is a (successor) state \(s'\) in \(\psi \) and a transition from s to \(s'\) with a label in A. Symmetrically, s is in \(\psi {\texttt {<}}A{\texttt {>}}\) if and only if there is a (predecessor) state \(s'\) in \(\psi \) and a transition from \(s'\) to s with a label in A. In the following, we will also use two constants, T, the true formula (matching all the states), and ‘0, that denotes the initial state of the model; and the least fixpoint operator min X | \(\psi \) (X).
For example, the formula \({\texttt {<}}\textsf {\small a}{\texttt {>T}}\) matches all the states that are the source of an a-transition, likewise \({\texttt {Reach\_}}\textsf {\small a} \ \overset{{{\tiny \mathrm{def}}}}{=} {} \texttt {min\;X}\,{\texttt {|}}\,{\texttt {(<}}\textsf {\small a}{\texttt {>T}}\ \,\vee \,{\texttt {<Z>X)}}\) matches all the states that can lead to an a-transition using only internal transitions. As a consequence, we can test innocuousness by checking that the formula \({\texttt {(Reach\_}}\textsf {\small a}\ \,\wedge \,{\texttt {Reach\_}}\textsf {\small b} \,\wedge \,{\texttt {Reach\_}}\textsf {\small t}{\texttt {)}}\) is true for all states.
The soundness proof relies on an encoding from regular path expressions into modal formulas. We define two encodings: \((({R}))_{}\) that matches the states encountered while firing a trace matching a regular expression R; and \((({R}))_{e}\) that matches the state reached (at the end) of a finite trace in R. These encodings rely on two derived operators. (Again, we assume here that A is a label expression.)
data:image/s3,"s3://crabby-images/9f8aa/9f8aa24749d3207a69e14214b092480246abd53d" alt=""
Lemma 1
Given a Kripke structure K, the states matching the formula \((({R}))_{e}\) (respectively \((({R}))_{}\)) in K are the states reachable from the initial state after firing (resp. all the states reachable while firing) a sequence of transitions matching R.
Proof
(Sketch). By induction on the definition of R. For example, if we assume that \(\psi \) correspond to the regular expression R, then \(\psi * A\) matches all the states reachable from states where \(\psi \) is true using (finite) sequences of transition with label in A; i.e. formula \(\psi \) * A corresponds to \(R \cdot A\mathclose {\overset{*}{\ }}\). Likewise, we use the interpretation of the empty expression, \(\epsilon \), to prefix every formula with the constant ‘0 (that will only match the initial state). This is necessary since \(\mu \)-calculus formulas are evaluated on all states whereas regular path expressions are evaluated from the initial state. \(\square \)
For example, we give the formula for \((({R_2}))_{e}\) below, where \(\psi \,{\texttt {o}}\,{\texttt {Tick}}\) stands for the expression \((\psi {\texttt {\,o\,t}}){\texttt {\,*\,(-t)}}\):
If \(\psi _{ Err }\) is a modal \(\mu \)-calculus formula that matches the error condition of the observer, then we can check the correctness and soundness of the observer Present by proving that the equivalence (EQ), below, is a tautology (that it is true on every states of (\(\textsf {\small Universal} \varvec{\,||\,}\textsf {\small Present}\))).
Again, we can interpret the “error condition” using the \(\mu \)-calculus. The definition of errors is a little bit more involved than in the previous case. We say that a state is in error if the transition error is enabled (the formula \({\texttt {<error>T}}\) is true) or if the state can only be reached by firing the error transition (which corresponds to the formula \({\texttt {(T<error>}}\,{\texttt {*}}\,{\texttt {T)}}\,\wedge \,\,{\texttt {(`0}}\,{\texttt {*}}\,(-~\texttt {error}))\). Hence \(\psi _{ Err }\) is the disjunction of these two properties:
The formula (EQ) can be checked almost immediately (less than 1 s on a standard computer) for models of a few thousands states using muse. Listing 1.3 gives a muse script file that can be used to test this equivalence relation.
data:image/s3,"s3://crabby-images/db3e7/db3e7f1cd289cc9a16754190c4d626551f345d48" alt="figure c"
6 Related Work and Conclusion
Few works consider the verification of model-checking tools. Indeed, most of the existing approaches concentrate on the verification of the model-checking algorithms, rather than on the verification of the tools themselves. For example, Smaus et al. [15] provide a formal proof of an algorithm for generating Büchi automata from a LTL formula using the Isabelle interactive theorem prover. This algorithm is at the heart of many LTL model checkers based on an automata-theoretic approach. The problem of verifying verification tools also appears in conjunction with certification issues. In particular, many certification norms, such as the DO-178B, requires that any tool used for the development of a critical equipment be qualified at the same level of criticality than the equipment. (Of course, certification does not necessarily mean formal proof!) In this context, we can cite the work done on the certification of the SCADE compiler [14], a tool-suite based on the synchronous language Lustre that integrates a model-checking engine. Nonetheless, only the code-generation part of the compiler is certified and not the verification part. Finally, another possibility is to rely on a kind of “Proof-Carrying Code” approach, where the model checker can produce a deductive proof on either success or failure [12]. This proof can then be checked separately, using a tool independent from the model checker.
Concerning observer-based model-checking, most of the works rely on an automatic way to synthesize observers from a formal definition of the properties. For instance, Aceto et al. [2] propose a method to verify properties based on the use of test automata. In this framework, verification is limited to safety and bounded liveness properties since the authors focus on properties that can be reduced to reachability checking. In the context of Time Petri Net, Toussaint et al. [16] also propose a verification technique based on “timed observers”, but they only consider four specific kinds of time constraints. None of these works consider the complexity or the correctness of the verification problem. Another related work is [9], where the authors define observers based on Timed Automata for each pattern. Our approach is quite orthogonal to the “synthesis approach”. Indeed we seek, for each property, to come up with the best possible observer in practice. To this end, using our toolchain, we compare the complexity of different implementations on a fixed set of representative examples and for a specific set of properties and kept the best candidates. The need to check multiple implementations for the same patterns has motivated the need to develop a lightweight verification method for checking their correctness.
Compared to these works, we make several contributions. We define a complete verification framework for checking observers with hard realtime constraints. This framework has been tested on a set of observers derived from high-level timed specification patterns. This work is also our first public application of the probe technology, that was added to Fiacre only recently. To the best of our knowledge, the notion of probes is totally new in the context of formal specification language. Paun and Chechik propose a somewhat similar mechanism in [6, 13]—in an untimed setting—where they define new categories of events. However our approach is more general, as we define probes for a richer set of events, such as variables changing state. We believe that this (language-level) notion of probes is interesting in its own right and could be adopted by other formal specification languages. Finally, we propose a formal approach that can be used to gain confidence on the implementation of our model-checking tools and that replaces traditional “visual verification methods” that are prone to human errors.
Notes
- 1.
Code is available at http://www.laas.fr/fiacre/examples/visualverif.html.
References
Abid, N., Dal Zilio, S., Le Botlan, D.: A formal framework to specify and verify real-time properties on critical systems. Int. J. Crit. Comput.-Based Syst. 5(1/2), 4–30 (2014)
Aceto, L., Burgueño, A., Larsen, K.G.: Model checking via reachability testing for timed automata. In: Steffen, B. (ed.) TACAS 1998. LNCS, vol. 1384, pp. 263–280. Springer, Heidelberg (1998)
Berthomieu, B., Bodeveix, J.-P., Fillali, M., Hubert, G., Lang, F., Peres, F., Saad, R., Jan, S., Vernadat, F.: The syntax and semantics of fiacre - version 3.0 (2012). http://www.laas.fr/fiacre/
Berthomieu, B., Ribet, P.-O., Vernadat, F.: The tool Tina - construction of abstract state spaces for Petri nets and time Petri nets. Int. J. Prod. Res. 42, 14 (2004)
Berthomieu, B., Bodeveix, J.-P., Farail, P., Filali, M., Garavel, H., Gaufillet, P., Lang, F., Vernadat, F.: Fiacre: an intermediate language for model verification in the topcased environment. In: Proceedings of ERTS (2008)
Chechik, M., Paun, D.O.: Events in property patterns. In: Dams, D.R., Gerth, R., Leue, S., Massink, M. (eds.) SPIN 1999. LNCS, vol. 1680, pp. 154–167. Springer, Heidelberg (1999)
Dwyer, M.B., Dillon, L.: Online repository of specification patterns. http://patterns.projects.cis.ksu.edu/
Garnacho, M., Bodeveix, J.-P., Filali-Amine, M.: A mechanized semantic framework for real-time systems. In: Braberman, V., Fribourg, L. (eds.) FORMATS 2013. LNCS, vol. 8053, pp. 106–120. Springer, Heidelberg (2013)
Gruhn, V., Laue, R.: Patterns for timed property specifications. Electr. Notes Theor. Comput. Sci. 153(2), 117–133 (2006)
Koymans, R.: Specifying realtime properties with metric temporal logic. Realtime Syst. 2, 255–299 (1990)
Merlin, P.M.: A study of the recoverability of computing systems. Ph.D. thesis (1974)
Namjoshi, K.S.: Certifying model checkers. In: Berry, G., Comon, H., Finkel, A. (eds.) CAV 2001. LNCS, vol. 2102, pp. 2–13. Springer, Heidelberg (2001)
Paun, D.O., Chechik, M.: Events in events in linear-time properties. CoRR J. vol. cs.SE/9906031 (1999)
Esterel technologies. SCADE Tool Suite. http://www.esterel-technologies.com/products/scade-suite
Schimpf, A., Merz, S., Smaus, J.-G.: Construction of Büchi automata for LTL model checking verified in Isabelle/HOL. In: Berghofer, S., Nipkow, T., Urban, C., Wenzel, M. (eds.) TPHOLs 2009. LNCS, vol. 5674, pp. 424–439. Springer, Heidelberg (2009)
Toussaint, J., Simonot-Lion, F., Thomesse, J.-P.: Time constraints verification methods based on time Petri nets. In: Proceedings of FTDCS. IEEE (1997)
Author information
Authors and Affiliations
Corresponding author
Editor information
Editors and Affiliations
Rights and permissions
Copyright information
© 2016 IFIP International Federation for Information Processing
About this paper
Cite this paper
Dal Zilio, S., Berthomieu, B. (2016). Automating the Verification of Realtime Observers Using Probes and the Modal mu-calculus. In: Hajiaghayi, M., Mousavi, M. (eds) Topics in Theoretical Computer Science. TTCS 2015. Lecture Notes in Computer Science(), vol 9541. Springer, Cham. https://doi.org/10.1007/978-3-319-28678-5_7
Download citation
DOI: https://doi.org/10.1007/978-3-319-28678-5_7
Published:
Publisher Name: Springer, Cham
Print ISBN: 978-3-319-28677-8
Online ISBN: 978-3-319-28678-5
eBook Packages: Computer ScienceComputer Science (R0)