data:image/s3,"s3://crabby-images/87178/87178aae405ad3e6c23e34d5ca162b17452e6ec0" alt="../images/483135_1_En_5_Chapter/483135_1_En_5_Figa_HTML.png"
1 Introduction
Signal Temporal Logic (STL [16, 17]) is a temporal logic designed to specify properties of real-valued dense-time signals. It gained popularity due to the rigour and the ability to reason about analog and mixed signals; and it found use in such domains as analog circuits, systems biology, cyber-physical control systems (see [3] for a survey). A major use of STL is in monitoring: given a signal and an STL formula, an automated procedure can decide whether the formula holds at a given time point.
Monitoring of STL is reliably efficient. A monitoring procedure typically traverses the formula bottom up, and for every sub-formula computes a satisfaction signal, based on satisfaction signals of its operands. Boolean monitoring is based on the computation of conjunctions and disjunctions over a sliding window (“until” is implemented using a specialized version of running conjunction), and robustness monitoring (computing how well a signal satisfies a formula [9, 10]) is based on the computation of minimum and maximum over a sliding window. The complexity of both Boolean and robustness monitoring is linear in the length of the signal and does not depend on the width of temporal windows appearing in the formula. At the same time, for a range of applications, pure STL is either not expressive enough or difficult to use, and specifying a desired property often becomes a puzzle of its own. The existence of robustness and other real-valued semantics does not always help, since a monitor can perform a limited set of operations that the semantics assigns to Boolean operators. For example, for robustness semantics, and
are the only operations beyond the atomic proposition level.
One way to work around the expressiveness issues of STL is pre-processing: a computation that cannot be performed by an STL monitor can be performed by a pre-processor and supplied as an extra input signal. For a number of reasons, this is not always satisfactory. First, for monitoring of continuous-time signals, there is a big gap between the logical definitions of properties and the implementation of monitors. In continuous-time setting, properties are defined using quantification, upper and lower bounds, and similar mathematical tools for dense sets, while a monitor works with a finite piecewise representation of a signal and performs a computation that is based on induction and other tools for discrete sets. Leaving this gap exposed to the user, who has to implement the pre-processing step, is not very user-friendly. Second, monitoring of some properties cannot be cleanly decomposed into a pre-processing step followed by standard STL monitoring. Later, we give a concrete example using an extended “until” operator, and for now, notice that “until” instructs the monitor to compute a conjunction over the window that is not fixed in advance, but is defined by its second operand. Because of that, multiple researches have been motivated to search for a more expressive superset of STL that would allow to specify the properties they were interested in.
One direction for extension is to add to the original quantifier-free logic (MTL, STL) a form of variable binding: a freeze quantifier as in STL* [6], a clock reset as in TPTL [1], or even first order quantification [2]. Unfortunately, such extensions are detrimental to complexity of monitoring. When monitoring logics with quantifiers using standard bottom-up approach, subformulas containing free variables evaluate not to Boolean- or real-valued signals, but to maps from time to non-convex sets, and they cannot in general be efficiently manipulated (although for some classes of formulas monitoring of logics with quantifiers works well [4, 13]). Perhaps the most benign in this respect but also least expressive extension is 1-TPTL (TPTL with one active clock), which is as expressive as MITL, but is easier to use and admits a reasonably efficient monitoring procedure [11].
An alternative direction is to define a quantifier-free specification language with more flexible syntax and sliding window operations. For example, Signal Convolution Logic (SCL [20]) allows to specify properties using convolution with a set of select kernels. In particular, it can express properties of the form “statement holds on an interval for at least X% of the time”. In SCL, every formula has a Boolean satisfaction signal, but some works go further and allow a formula to produce a real-valued output signal based on the real-valued signals of its subformulas. This already happens for robustness of STL in a very limited way, and can be extended. For example, [19] presents temporal logic monitoring as filtering, which allows to derive multiple different real-valued semantics. Another work [7] focuses on the practical application of robustness in falsification and allows to choose between different possible robust semantics for “eventually” and “always”, in particular to replace
or
with integration where necessary.
This paper is our take on extending STL in the latter direction. We define a specification language that is more expressive than STL, but not less efficient to monitor offline, i.e., the complexity of monitoring is linear in the length of the signal and does not depend on the width of temporal windows in the formula (the latter property tends to be missing from the STL extensions, even when the authors can achieve linear complexity for a fixed formula). The most important features of the new language are as follows.
- 1.
We remove several syntactic constrains from STL: we allow a formula to have a real-valued output signal; we allow these signals to be combined in a point-wise way with arithmetic operations, comparisons, etc. This distinguishes us from the works that use standard MTL or STL syntax and assign them new semantics [10, 19].
- 2.
We allow to apply an efficiently computable aggregate function over a sliding window. We currently focus on
and
, which are enough to specify properties that motivated the development of more expressive and hard to monitor logics.
- 3.
We offer a version of “until” operator that performs aggregation over a sliding window of dynamic width, that depends on satisfaction of some formula. This distinguishes us from the works that focus on aggregation over a fixed window [20].
Finally, we focus our attention on continuous-time piecewise-constant and piecewise linear signals; we describe the algorithms and prepare an implementation only for piecewise-constant.
2 Motivating Examples
Before formally defining the new language, let us look at some examples of properties that we would like to express. In particular, we look at properties that motivated the development of more expressive and harder to monitor logics.
Example 1
data:image/s3,"s3://crabby-images/f896d/f896d9cbeaf5c42989c76f3af4b38ee779545168" alt="$$0.1 = 2 \cdot 0.05$$"
![$$\max _{[0,200]} x - \min _{[0,200]} x \le 0.1$$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_IEq9.png)
![$$\mathop {\mathrm {On}_{[a,b]}}$$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_IEq10.png)
data:image/s3,"s3://crabby-images/4a552/4a552e8aa12918534b8a3134f5d14755f1b352ce" alt="$$\mathop {\mathrm {Min}}$$"
data:image/s3,"s3://crabby-images/fb2eb/fb2eb24643a1051ba495d8d4f667caf4c610e141" alt="$$\mathop {\mathrm {Max}}$$"
![$$ \mathop {\mathrm {On}_{[0,200]}} \mathop {\mathrm {Max}}x - \mathop {\mathrm {On}_{[0,200]}} \mathop {\mathrm {Min}}x \le 0.1 $$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_Equ4.png)
![$$[t, t+200]$$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_IEq13.png)
data:image/s3,"s3://crabby-images/dd2e1/dd2e1456390c277561beb412898cebd04f867159" alt="$$y = 1$$"
data:image/s3,"s3://crabby-images/e2115/e21159fdfb3c08e42827ad5cdc14a4b310400616" alt="../images/483135_1_En_5_Chapter/483135_1_En_5_Fig1_HTML.png"
Damped oscillation x(t) and its maximum and minimum over the window . (Color figure online)
data:image/s3,"s3://crabby-images/6f1ab/6f1ab8e16b70666a2fdfcbe0353ed674ca718af3" alt="../images/483135_1_En_5_Chapter/483135_1_En_5_Fig2_HTML.png"
Sine wave x(t), its maximum over the window , and whether x(t) is a local maximum on the interval
. (Color figure online)
Example 2
(Local Maximum). Consider the property: “the current value of x is a minimum or maximum in some neighbourhood of current time point”. Previously, a similar property became a motivation to extend STL with freeze quantifiers [6], but we can also express it by comparing the value of a signal with some aggregate information about its neighbourhood, which we can do similarly to the previous example.
![$$ x \ge \mathop {\mathrm {On}_{[0,85]}} \mathop {\mathrm {Max}}x $$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_Equ5.png)
![$$[t, t+85]$$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_IEq18.png)
Example 3
(Stabilization Contd.). We want to be able to assert that x becomes stable around some value not for a fixed duration, but until some signal q becomes true. We will be able to do this with our version of “until” operator.
data:image/s3,"s3://crabby-images/6f641/6f641912cbd75f60ec311f4504d01d8b16f7bc8d" alt="$$ (\mathop {\mathrm {Max}}x \mathbin {\mathrm {U}_{}^{}} q) - (\mathop {\mathrm {Min}}x \mathbin {\mathrm {U}_{}^{}} q) \le 0.1 $$"
data:image/s3,"s3://crabby-images/ef851/ef85178244e43f5e7a6ff18063021ba170d0245b" alt="$$\mathop {\mathrm {Min}}$$"
data:image/s3,"s3://crabby-images/ea462/ea4621f4decbc76c964dd133cc05aeaa72f861af" alt="$$\mathop {\mathrm {Max}}$$"
data:image/s3,"s3://crabby-images/13a2c/13a2c2d0f6b986f5110287915f1c9d8e2b753dd8" alt="$$\mathop {\mathrm {Min}}$$"
data:image/s3,"s3://crabby-images/dde06/dde066eb55e1fb7b73187a96ecd52edef40b9e1d" alt="$$\mathop {\mathrm {Max}}$$"
Example 4
(Linear Increase). At this point, we can assert x to follow a more complex shape, for example, to increase or decrease with a given slope. Let T denote an auxiliary signal that linearly increases with rate 1 (like a clock of a timed automaton), i.e. we define ; this example works as well for
, where c is a constant. To specify that x increases with the rate 2.5, we assert that the distance from x to
stays within some bounds.
![$$ \mathop {\mathrm {On}_{[0,100]}} \mathop {\mathrm {Max}}|x - 2.5\mathrm {T}| - \mathop {\mathrm {On}_{[0,100]}} \mathop {\mathrm {Min}}|x - 2.5\mathrm {T}| \le 0.1 $$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_Equ7.png)
3 Syntax and Semantics
From the examples above we can foresee how the new language looks like. Formally, an (input) signal is a function , where the time domain
is a closed real interval
, and the number |w| is the duration of the signal. We refer to signal components using their own letters:
. We assume that every signal component is piecewise-constant or piecewise-linear.
The semantics of a formula is a piecewise-constant or piecewise-linear function from real time (thus, has real-valued switching points) to a dual number (rather than a real). We defer the discussion of dual numbers until Sect. 3.2; for now we note that they extend reals, and a dual number can be written in the form , which, when
, denotes a point infinitely close to a. We denote the set of dual numbers as
. Our primary use of a dual number is to represent a time point strictly after an event (switching point, threshold crossing, etc.) but before any other event can happen; as a result we have to allow an output signal to have a dual value, denoting a value that is attained at this dual time point.
data:image/s3,"s3://crabby-images/ba795/ba795bca5b1dc474e60ac101a73e750b768e1dd8" alt="../images/483135_1_En_5_Chapter/483135_1_En_5_Equ1_HTML.png"
data:image/s3,"s3://crabby-images/a5b6a/a5b6a7e4beabc5ee099b7e481c9d26d8735c4a4c" alt="$$\mathrm {On}$$"
data:image/s3,"s3://crabby-images/99150/99150999b3bb0054290728f7632c376de2286944" alt="$$\pm \infty $$"
data:image/s3,"s3://crabby-images/909c3/909c3a05f0bd5c20de829447cae529ab3be87752" alt="$$\mathrm {U}$$"
data:image/s3,"s3://crabby-images/b88a5/b88a518df3b69f44a9a83691f6ab7162919b7150" alt="$$\infty $$"
Point-wise Functions. Function symbol f ranges over real-valued functions that preserve the chosen shape of signals (and can be lifted to dual numbers). In this paper, we focus on piecewise-constant and piecewise-linear signals, so when f is applied point-wise to a piecewise-constant input, we want the result to be piecewise-constant; when f is applied point-wise to a piecewise-linear input, we want the result to be piecewise-linear. Examples of such functions are addition, subtraction,
and
of finitely many operands (we use lowercase
and
to denote a real-valued n-ary function), multiplication by a constant, absolute value, etc.
![$$\mathop {\mathrm {On}_{[0,85]}} \mathop {\mathrm {Max}}x$$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_IEq42.png)
![$$x \ge \mathop {\mathrm {On}_{[0,85]}} \mathop {\mathrm {Max}}x$$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_IEq43.png)
data:image/s3,"s3://crabby-images/9b19f/9b19f06052d19fe4ae3fd71504ecbf69ba91f863" alt="$$\{0, 1\}$$"
data:image/s3,"s3://crabby-images/a8e74/a8e740ad90722cc34297540dcafa5c56c144e2ec" alt="$$\varphi _1 \le \varphi _2$$"
data:image/s3,"s3://crabby-images/6b2f3/6b2f34b6262e37542bf85423d915f696e9ae9308" alt="$$\varphi _1 \le \varphi _2$$"
data:image/s3,"s3://crabby-images/66ed7/66ed7c9851257c183ad70e0bc4d32b2e46983977" alt="$$ \varphi _1 \wedge \varphi _2 = \min \{\varphi _1, \varphi _2\} \qquad \quad \varphi _1 \vee \varphi _2 = \max \{ \varphi _1, \varphi _2 \} \qquad \quad \lnot \varphi = 1 - \varphi $$"
data:image/s3,"s3://crabby-images/4f9c4/4f9c400a42ccefc94c8a2ce62b3eccac6b0e8cb4" alt="$$\varvec{\varphi }$$"
data:image/s3,"s3://crabby-images/328b0/328b0dd6dd26c46f6fe502f63f591f4fe8e3fbcb" alt="$$\varphi $$"
data:image/s3,"s3://crabby-images/5b873/5b8731da6818bbe797f26d157b877e0b22a4bcbd" alt="$$\varphi $$"
- 1.
refer to an input signal x;
- 2.
apply a real-valued function f pointwise to the outputs its
-subformulas;
- 3.
apply an aggregate function over the sliding window [a, b] (with some abuse of notation a can be
, and b can be
);
- 4.
be an “until” formula, which is described in Sect. 3.3.
data:image/s3,"s3://crabby-images/97a61/97a6101a5bfbd890782f5dfdc5fe0c29f872a667" alt="$$\varvec{\psi }$$"
data:image/s3,"s3://crabby-images/5381f/5381f2b0c177b027923f83e74656f140765acbd7" alt="$$\psi $$"
data:image/s3,"s3://crabby-images/9ff01/9ff01608d48f472111ef7fd61460df248f3808b8" alt="$$\mathrm {On}$$"
data:image/s3,"s3://crabby-images/63150/631501062f67de6492b81ca3c5b4973b8c2abdb4" alt="$$\mathop {\mathrm {Min}}$$"
data:image/s3,"s3://crabby-images/4d048/4d048a3374d49da77b136b1b726e31e00a023daf" alt="$$\mathop {\mathrm {Max}}$$"
![$$ \mathop {\mathrm {F}_{[a,b]}} \varphi = \mathop {\mathrm {On}_{[a,b]}} \mathop {\mathrm {Max}}\varphi \qquad \qquad \mathop {\mathrm {G}_{[a,b]}} \varphi = \mathop {\mathrm {On}_{[a,b]}} \mathop {\mathrm {Min}}\varphi $$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_Equ9.png)
3.1 Semantics of Until-Free Fragment
data:image/s3,"s3://crabby-images/3b709/3b7095c025c96897c88e697a6aa0f15e7027f7de" alt="$$\varphi $$"
data:image/s3,"s3://crabby-images/5d7a9/5d7a9c6049c59c49e56bc3773ab7a25140d16186" alt="$$\llbracket \varphi \rrbracket : \mathbb {T}\rightarrow \mathbb {R}_{\varepsilon }$$"
data:image/s3,"s3://crabby-images/2af89/2af8964402a9feff86e59cfd1f57e0eaeee37a6e" alt="../images/483135_1_En_5_Chapter/483135_1_En_5_Equ2_HTML.png"
data:image/s3,"s3://crabby-images/cd35c/cd35caded8e42adbda6edc3bb0ea5f52f353978c" alt="$$\psi $$"
data:image/s3,"s3://crabby-images/4f62d/4f62defa2b17694de00c9763eae3e175186b4df7" alt="$$\llbracket \psi \rrbracket : (\mathbb {R}\cup -\infty )\times (\mathbb {R}_{\varepsilon }\cup \infty )\rightarrow \mathbb {R}_{\varepsilon }$$"
data:image/s3,"s3://crabby-images/d4537/d45376853580eae238e28a7aff32249f3d59eb98" alt="../images/483135_1_En_5_Chapter/483135_1_En_5_Equ3_HTML.png"
data:image/s3,"s3://crabby-images/c335d/c335d29ab929ec6dbfc4caa403ab18853eba0639" alt="$$\min $$"
data:image/s3,"s3://crabby-images/c9560/c95604ad0f33f144619e7269e0dfd14a287a5ccb" alt="$$\max $$"
3.2 Dual Numbers
Dual numbers extend reals with a new element that has a property
. A dual number can be written in a form
, where
. We denote the set of dual numbers as
. Dual numbers were proposed by the English mathematician W. Clifford in 1873 and later applied in geometry by the German mathematician E. Study. One of modern applications of dual numbers and their extensions is in automatic differentiation [12]: one can exactly compute the value of the first derivative at a given point using the identity
. Intuitively,
can be understood as an infinitesimal value, and
(for
) is a point that is infinitely close to a. Polynomial functions can be extended to dual numbers, and via Taylor expansion, so can exponents, logarithms, and trigonometric functions. We work with piecewise-constant and piecewise-linear functions with real switching points, and we only make use of basic arithmetic. For example, if on the interval
the signal x is defined as
, then
and
.
Our primary use of a dual number is to represent a time point strictly after an event (a switching point, a threshold crossing, etc.) but before any other event can happen, i.e., we use to represent the time point that happens right after
. The coefficient 1 at
denotes that time advances with the rate of 1 (although another consistently used coefficient works as well). Consequently, we also allow an output signal to produce a dual value, denoting a value that is attained at this dual time point. On the other hand, we require that signals are defined over real time, switching points of piecewise signals are reals, and time constants in formulas are reals. That is, dual-valued time is only used internally by the temporal operators and cannot be directly observed.
data:image/s3,"s3://crabby-images/efe86/efe8646150b756f27cfcf8393ffa8a042daa1db1" alt="$$\mathop {\mathrm {Min}}$$"
data:image/s3,"s3://crabby-images/25734/257340fd6f6a62bad3700bb660a5142260124550" alt="$$\mathop {\mathrm {Max}}$$"
data:image/s3,"s3://crabby-images/5594e/5594efbd06a22fe46b5ff03837d16e167530d9e1" alt="$$t \in (b_1, b_2)$$"
data:image/s3,"s3://crabby-images/44aef/44aef3627889c68abd2b897a3ee859ef886e8fae" alt="$$x(t) = a_1 t + a_2$$"
data:image/s3,"s3://crabby-images/40123/40123c18a505a8e21c4c2fdc60ca8accb81b8668" alt="$$b_1+\varepsilon $$"
data:image/s3,"s3://crabby-images/cb597/cb597557d6abfafc5e9ac65ff3db85fd95bf3ec2" alt="$$b_2-\varepsilon $$"
data:image/s3,"s3://crabby-images/4a3bd/4a3bd0b7a3e037a1f700bf0fc3fd361cf7b8ca67" alt="../images/483135_1_En_5_Chapter/483135_1_En_5_Fig3_HTML.png"
Signals x and y for Example 8.
data:image/s3,"s3://crabby-images/d2131/d213165afec95bf4d224b7c6cb95239643105055" alt="../images/483135_1_En_5_Chapter/483135_1_En_5_Fig4_HTML.png"
Example 5
Consider the signal x defined as: “”, as shown in Fig. 4. Let us find the minimum of x on the interval
. By our definition,
. This result should be understood as follows: x(t) approaches the value of 1 from the above with derivative
, but never reaches it.
Example 6
Our definition of minimum and maximum allows to correctly compare values of piecewise-linear functions around their discontinuity points. In Example 5, x never reaches the value of its lower bound, and our definition of minimum produces a dual number that reflects this fact and also specifies the rate at which x approaches its lower bound. This information would be lost if we computed the infimum of x. Again consider the signals in Fig. 4, with x defined as before, and “”. Let us evaluate at time
the formula
, which denotes the property
. From the previous example, we have that
. By a similar argument,
, which means that y approaches 1 from below with the rate of 1. Since,
, our property holds at time 0, as expected.
We want to emphasize that while an output signal can take a dual value, its domain is considered to be a subset of reals. The semantics of temporal operators are allowed to internally use dual-valued time points, but has to produce an output signal that is defined over real time. This ensures that a piecewise signal always has real-valued switching points and that no event can happen at a dual-valued time point.
Example 7
![$$\varphi = \mathop {\mathrm {F}_{[0,2]}} (x = \mathop {\mathrm {On}_{(-\inf ,\inf )}} \mathop {\mathrm {Min}}x)$$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_IEq97.png)
data:image/s3,"s3://crabby-images/3db4a/3db4a07510ff1ee3b6d1793d1cc8f5c919a8ee35" alt="$$\varphi $$"
data:image/s3,"s3://crabby-images/35b94/35b94532486ab89c6c9fa1e5a597af9640f4bf0f" alt="$$1+0.5\varepsilon $$"
data:image/s3,"s3://crabby-images/268af/268afc7a43bb46451bd64bcd189b8344fceb862a" alt="../images/483135_1_En_5_Chapter/483135_1_En_5_Equ19_HTML.png"
![$$\mathbb {T}=[0,|w|] \subseteq \mathbb {R}$$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_IEq100.png)
3.3 Semantics of Until
The -operator allowed us to compute minima and maxima over a sliding window of fixed width. In this section, we introduce a new version of “until” operator that allows the window to have variable width that depends on the output signal of some formula.
![$$ \llbracket p \mathbin {\mathrm {U}_{}^\mathrm{STL}} q \rrbracket (t) = \exists t' \ge t.\ q(t') \wedge \forall s \in [t, t'].\ p(s) $$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_Equ10.png)
data:image/s3,"s3://crabby-images/3550b/3550bbb2f21088b5c208ac576ea3c88315a6ab76" alt="$$\mathbin {\mathrm {U}_{}^\mathrm{STL}}$$"
data:image/s3,"s3://crabby-images/bf543/bf543490209d323f1786c3a61a05e059a40176c5" alt="$$t'$$"
data:image/s3,"s3://crabby-images/f7cc6/f7cc6df7f61c00105a3de9b41517a4d8011007d7" alt="$$t'$$"
data:image/s3,"s3://crabby-images/697bc/697bc6c157397e762ea1d34e8a9b0d4d1c9fe33b" alt="../images/483135_1_En_5_Chapter/483135_1_En_5_Fig5_HTML.png"
Case 1: q is never true in the future.
data:image/s3,"s3://crabby-images/7b78b/7b78b608351113281e60c9865aca248da800f649" alt="../images/483135_1_En_5_Chapter/483135_1_En_5_Fig6_HTML.png"
Case 2: q there exists the earliest time point, where q becomes true.
data:image/s3,"s3://crabby-images/6417a/6417ac72b5627db443c7a97e150db157178588c8" alt="../images/483135_1_En_5_Chapter/483135_1_En_5_Fig7_HTML.png"
Case 3: q becomes true, but there is no earliest time point.
- 1.
Figure 5: q is false for every
. Then the value of
at t is false.
- 2.
Figure 6: there exists the smallest
, where q is true (this includes the case, where
). Then the value of
at t is
(predicate p is not shown in the figure). The monitor needs not consider time points after
, since if “forall” produces false on a smaller interval, it will produce false on a larger one.
- 3.
Figure 7: q becomes true in the future, but there is no earliest time point. In this case, the monitor needs to take the universal quantification over an interval that ends just after
(the switching point of q), but before any other event occurs. We can formalize this reasoning using dual numbers and say that the value of
at t is
, where
can be intuitively understood as a time point that happens after
, but before any other event can occur.
data:image/s3,"s3://crabby-images/39645/39645b067c8c7bb323a101336da96a598a6b2f5f" alt="../images/483135_1_En_5_Chapter/483135_1_En_5_Equ20_HTML.png"
Example 8
Let us consider two linear input signals: and
(see Fig. 3), and let us evaluate the formula
at time 0 using non-strict “until” semantics. We define the earliest time point where
becomes true to be
, thus we need to evaluate the expression
. At time
, we get
, thus the “until” formula does not hold. Informally, we can interpret the result as follows: when x becomes greater than 1, y becomes greater than x, while non-strict “until” requires that there exists a point, where both its left- and right-hand operands hold at the same time.
![$$\psi \mathbin {\mathrm {U}_{[a,b]}^{d}} \varphi $$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_IEq125.png)
data:image/s3,"s3://crabby-images/2dc95/2dc95c37dde8fa2af5318e385a8278ca3effa00f" alt="$$\varphi $$"
data:image/s3,"s3://crabby-images/43d5e/43d5e646b02868e96a60c927f9d8f1144e91bed9" alt="$$\psi $$"
![$$ \llbracket \psi \mathbin {\mathrm {U}_{[a,b]}^{d}} \varphi \rrbracket (t) = {\left\{ \begin{array}{ll} \llbracket \psi \rrbracket [t, t'], \text { if } \exists \text { the smallest } t'\in [t+a,t+b], \text { s.t. } \llbracket \varphi \rrbracket (t') \ne 0 \\ \begin{aligned} \llbracket \psi \rrbracket &{}[t, t'+\varepsilon ], \text { where } t' = \inf \{ t' | t' \in [t+a,t+b] \wedge \llbracket \varphi \rrbracket (t') \}, \\ &{} \text { if } \exists t' \in [t+a,t+b].\ \llbracket \varphi \rrbracket (t') \ne 0, \text{ but } \text{ there } \text{ is } \text{ no } \text{ smallest } t' \end{aligned} \\ d, \text { otherwise } \end{array}\right. } $$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_Equ11.png)
![$$\varphi _1\!\downarrow \mathbin {\mathrm {U}_{[a,b]}^{d}} \varphi _2$$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_IEq128.png)
data:image/s3,"s3://crabby-images/17fd6/17fd6ebebd9e9d2ceab0a0af66d280033d3e2c04" alt="$$\varphi _1$$"
data:image/s3,"s3://crabby-images/c04b7/c04b72ba2783711c80ed3d2270aa199a4065d16f" alt="$$\varphi _2$$"
![$$ \llbracket \varphi _1\!\downarrow \mathbin {\mathrm {U}_{[a,b]}^{d}} \varphi _2 \rrbracket (t) = {\left\{ \begin{array}{ll} \llbracket \varphi _1 \rrbracket (t'), \text { if }\exists \text { the smallest } t'\in [t+a,t+b], \text { s.t. } \llbracket \varphi _2 \rrbracket (t') \ne 0 \\ \begin{aligned} \llbracket \varphi _1 \rrbracket &{}(t'+\varepsilon ), \text { where } t' = \inf \{ t' | t' \in [t+a,t+b] \wedge \llbracket \varphi _2 \rrbracket (t') \}, \\ &{} \text { if } \exists t' \in [t+a,t+b].\ \llbracket \varphi _2 \rrbracket (t') \ne 0, \text{ but } \text{ there } \text{ is } \text{ no } \text{ smallest } t' \end{aligned} \\ d, \text { otherwise } \end{array}\right. } $$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_Equ12.png)
![$$ \varphi _1 \mathbin {\mathrm {U}_{[a,b]}^\mathrm{STL}} \varphi _2 = (\mathop {\mathrm {Min}}\varphi _1) \mathbin {\mathrm {U}_{[a,b]}^{0}} \varphi _2 $$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_Equ13.png)
![$$ \mathop {\mathrm {D}_{a}^{d}} \varphi = \varphi \!\downarrow \mathbin {\mathrm {U}_{[a,a]}^{d}} 1 $$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_Equ14.png)
data:image/s3,"s3://crabby-images/c4480/c4480a608a12063d1e8651417ac6ee36fff6c40f" alt="../images/483135_1_En_5_Chapter/483135_1_En_5_Fig8_HTML.png"
Before time 2, an event p is followed by an event q.
data:image/s3,"s3://crabby-images/bf93d/bf93d40d071f803e9c1f12887670041e1c5aeb49" alt="../images/483135_1_En_5_Chapter/483135_1_En_5_Fig9_HTML.png"
A sequence of spikes and a Boolean signal marking the detected start times of spikes. (Color figure online)
Example 9
![$$x' > m \wedge \mathop {\mathrm {F}_{[0,d]}} (x' < -m)$$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_IEq131.png)
data:image/s3,"s3://crabby-images/b17fb/b17fbc512f31d3f209b97de69dd88ac753d6667d" alt="$$x'$$"
data:image/s3,"s3://crabby-images/180e5/180e5868c1ec11c5b5e87536742b261118bd2453" alt="$$x'(t) = (x(t+\delta ) - x(t))/\delta $$"
data:image/s3,"s3://crabby-images/f552e/f552e7d54da6be73d71027e9ec0d7a7aacbb9379" alt="$$x'$$"
![$$ (\mathop {\mathrm {D}_{\delta }^{y}} x - x)/\delta \ge m \wedge \mathop {\mathrm {F}_{[0,d]}} ((\mathop {\mathrm {D}_{\delta }^{y}} x - x)/\delta \le -m) $$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_Equ15.png)
Example 10
![$$ (\mathop {\mathrm {On}_{[0,w]}} \mathop {\mathrm {Max}}x \ge x + m) \wedge \mathop {\mathrm {F}_{[0,w]}}(\mathop {\mathrm {On}_{[0,w]}} \mathop {\mathrm {Min}}x \le x - m) $$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_Equ16.png)
Example 11
(TPTL-like Assertion). The second form of “until” allows to reason explicitly about time points and durations, somewhat similarly to TPTL. Consider the property “within 2 time units, we should observe an event p followed by an event q” (Fig. 8 shows an example of a satisfying signal). With some case analysis, this property can be expressed in MTL [5], but probably the best way to express it is offered by TPTL, that allows to assert “”, meaning “reset a clock c, eventually, we should observe p and from that point, eventually we should observe q, while the clock value will be at most 2”. To express the property in our language, we introduce three auxiliary signals:
(which we use in some other examples as well),
, which denotes the duration until the next occurrence of p and similarly
, the duration until the next occurrence of q. Then, the property can be expressed as:
.
4 Monitoring
Similarly to other works on STL monitoring (e.g., [9]), we implement the algorithms for a subset of the language, and support the remaining operators via rewriting rules.
data:image/s3,"s3://crabby-images/f4da9/f4da90523240e017513f086c87354a295e7a7624" alt="$$\mathrm {On}$$"
![$$ \begin{aligned}&(\mathop {\mathrm {Min}}\varphi _1) \mathbin {\mathrm {U}_{[a,b]}^{d}} \varphi _2 = \text { if } \lnot \mathop {\mathrm {F}_{[a,b]}}\varphi _2 \text { then } d \text { else } \mathop {\mathrm {On}_{[0,a]}} \mathop {\mathrm {Min}}((\mathop {\mathrm {Min}}\varphi _1) \mathbin {\mathrm {U}_{}^{}} \varphi _2) \\&(\mathop {\mathrm {Max}}\varphi _1) \mathbin {\mathrm {U}_{[a,b]}^{d}} \varphi _2 = \text { if } \lnot \mathop {\mathrm {F}_{[a,b]}}\varphi _2 \text { then } d \text { else } \mathop {\mathrm {On}_{[0,a]}} \mathop {\mathrm {Max}}((\mathop {\mathrm {Max}}\varphi _1) \mathbin {\mathrm {U}_{}^{}} \varphi _2) \\&\varphi _1\!\downarrow \mathbin {\mathrm {U}_{[a,b]}^{d}} \varphi _2 = \text { if } \lnot \mathop {\mathrm {F}_{[a,b]}}\varphi _2 \text { then } d \text { else } \mathop {\mathrm {D}_{a}^{}} (\varphi _1\!\downarrow \mathbin {\mathrm {U}_{}^{}} \varphi _2) \end{aligned} $$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_Equ17.png)
![$$(\mathop {\mathrm {Min}}\varphi _1) \mathbin {\mathrm {U}_{[a,b]}^{d}} \varphi _2$$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_IEq141.png)
![$$s \in [t+a, t+b]$$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_IEq142.png)
data:image/s3,"s3://crabby-images/3d645/3d64534ac301af04fa5c97b1db8abd44d281e0ec" alt="$$\varphi _2$$"
![$$[t+a, t+b]$$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_IEq144.png)
data:image/s3,"s3://crabby-images/86bfd/86bfdf780ab7ccb8e18b05a5642179580423b606" alt="$$\varphi _2$$"
data:image/s3,"s3://crabby-images/7819c/7819c9fe1d89a39d5bdb53e9fa1dd80b2ceda51c" alt="../images/483135_1_En_5_Chapter/483135_1_En_5_IEq146_HTML.gif"
data:image/s3,"s3://crabby-images/2db80/2db800aaca4c3bd2ae4d238bd4f763fe6e2b61e6" alt="../images/483135_1_En_5_Chapter/483135_1_En_5_IEq147_HTML.gif"
data:image/s3,"s3://crabby-images/4be32/4be321a13b83571127246d06f06d51eceea3ec93" alt="$$t'$$"
data:image/s3,"s3://crabby-images/03602/036026972014c89821812f462dcd5a57bb5a6d7f" alt="$$g(t')$$"
data:image/s3,"s3://crabby-images/3d3a7/3d3a73eabce72a327ab5839bd99bf24ad8684568" alt="$$\varphi _2$$"
data:image/s3,"s3://crabby-images/2fc35/2fc355a1268d73170ac38f70d13d2626e086931e" alt="$$t' = t+a$$"
data:image/s3,"s3://crabby-images/cd600/cd600ebf3143c01e9d2463bc25b918f9a773b8fe" alt="../images/483135_1_En_5_Chapter/483135_1_En_5_IEq152_HTML.gif"
data:image/s3,"s3://crabby-images/a9ad7/a9ad7f80a7660a8499d1b708e086dccf72580f48" alt="../images/483135_1_En_5_Chapter/483135_1_En_5_IEq153_HTML.gif"
![$$g(t') \in [t', s]$$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_IEq154.png)
data:image/s3,"s3://crabby-images/dd89e/dd89ef7b007b9691988bdbbfa2814f5c3d6f3dbf" alt="$$g(t+a) = s$$"
![$$\bigcup \{ [t', g(t')] \mid t' \in [t, t+a] \} = [t, s]$$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_IEq156.png)
![$$\mathop {\mathrm {On}_{[a,b]}}$$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_IEq157.png)
data:image/s3,"s3://crabby-images/f18af/f18aff1cdd11aa4674a45141af502250cf0f794a" alt="$$a < 0$$"
data:image/s3,"s3://crabby-images/45c02/45c024725f5ee5a5d023aae24d0422425f36ca57" alt="$$b > 0$$"
data:image/s3,"s3://crabby-images/29991/2999150fc2fe47869dc4a059f83cced1b4e685de" alt="$$\mathop {\mathrm {Min}}/\mathop {\mathrm {Max}}$$"
data:image/s3,"s3://crabby-images/2b568/2b56801d5d270515cd42e13ffc87aa1016fc1fbe" alt="$$a < 0$$"
data:image/s3,"s3://crabby-images/ba937/ba937db2bc59c74678a522e9096229fb5f9b4ffa" alt="$$b > 0$$"
![$$ \begin{aligned}&\mathop {\mathrm {On}_{[a,b]}} \mathop {\mathrm {Min}}\varphi = \min \{ \mathop {\mathrm {On}_{[a,0]}} \mathop {\mathrm {Min}}\varphi ,\ \mathop {\mathrm {On}_{[0,b]}} \mathop {\mathrm {Min}}\varphi \} \\&\mathop {\mathrm {On}_{[a,b]}} \mathop {\mathrm {Max}}\varphi = \max \{ \mathop {\mathrm {On}_{[a,0]}} \mathop {\mathrm {Max}}\varphi ,\ \mathop {\mathrm {On}_{[0,b]}} \mathop {\mathrm {Max}}\varphi \} \end{aligned} $$](../images/483135_1_En_5_Chapter/483135_1_En_5_Chapter_TeX_Equ18.png)
data:image/s3,"s3://crabby-images/f3e1a/f3e1ac6ee6a142328237dc3e58c8fb30a3e68a32" alt="../images/483135_1_En_5_Chapter/483135_1_En_5_Equ21_HTML.png"
data:image/s3,"s3://crabby-images/9d1ea/9d1eafb28c8015923a268d6c34dbb0f1304ac572" alt="$$a \ge 0$$"
data:image/s3,"s3://crabby-images/daf8f/daf8f8bed2f0ad48c3fb62f123330d85ef27cc17" alt="$$b \le 0$$"
All operators in the language of the monitor admit efficient offline monitoring. Minimum and maximum over a sliding window required by the -operator can be computed using a variation of Lemire’s algorithm [9, 15]; “lookup” operator
shifts its input signal by a constant distance; and for untimed “until” we can scan the input signal backwards and perform a special case of running minimum or maximum.
4.1 Monitoring Algorithms
In this section, we briefly describe monitoring algorithms for piecewise-constant signals.
Representation of Signals. We represent a piecewise-constant function or
as a sequence of segments:
, where every segment
maps an interval
to a real or dual value
. The intervals
form a partition the domain of the signal and are ordered in ascending time order, i.e.,
and
. The domain of the signal corresponding to the sequence
is denoted by
. For example, if the function x(t) is defined as
, if
, and
, if
, then x(t) is represented by the sequence
, and
.
Empty brackets denote an empty sequence that does not represent a valid signal, but can be used by algorithms as an intermediate value. We manipulate the sequences with two main operations. The function
adds a segment to the end of a sequence:
. The function
adds a segment to the start of a sequence:
. This may produce a sequence where the first segment does not start time at time 0. While such a sequence does not represent a valid signal, it can be used by the algorithms as an intermediate value. The function
removes the last segment of a sequence, assuming it was non-empty:
.
An output signal of a formula is scalar-valued and is represented by one such sequence. An input signal usually has multiple components, i.e., it is a function , and is represented by a set of n sequences.
On-Formulas. For and
, a monitor needs to compute the minimum or maximum of the output signal of
over the sliding window. The corresponding algorithm was developed for discrete time by Lemire [15] and later adapted for continuous time [9].
data:image/s3,"s3://crabby-images/b23c5/b23c554e1ddca433fc3c670cb778c5a1bedbf10a" alt="$$\mathop {\mathrm {D}_{a}^{d}} \varphi $$"
data:image/s3,"s3://crabby-images/4fd55/4fd554fbcd0e2ec3f8d69d9d6274c7bd233c8afa" alt="$$u_{\varphi }$$"
data:image/s3,"s3://crabby-images/ba4de/ba4de2489d02087a653896754c7da852d81828b2" alt="$$\varphi $$"
data:image/s3,"s3://crabby-images/ab236/ab236f3ad713e3829efa672c817cd075354a9ca8" alt="../images/483135_1_En_5_Chapter/483135_1_En_5_Fig10_HTML.png"
Algorithm for monitoring “until”-formulas.
Until-Formulas. Informally, monitoring the “until”-formulas, ,
, and
, works as follows. The monitor scans the output signals of
and
backwards. While
evaluates to a non-zero value, the monitor outputs the value of
. When
evaluates to 0, the monitor outputs either the default value (if the monitor did not yet encounter a non-zero value of
), or the running minimum or maximum of
, or the value that
had at the last time point where
was non-zero.
The function and
in Fig. 10 implement this idea. The inputs to the function
are: sequences
and
representing the output signals of
and
(with
), default value d, and the function f used for aggregation; it can be
,
, or the special function
which returns the value of its first argument and which we use to monitor the formula
. The function
scans the input sequences backwards and iterates over intervals where both input signals maintain a constant value (J). Each such interval is passed to the function
, which updates the state of the algorithm (
, s) and constructs the output signal (
).
5 Implementation and Experiments
We implemented the monitoring algorithm in a prototype tool that is available at https://gitlab.com/abakhirkin/StlEval. The tool has a number of limitations, notably it can only use piecewise-constant interpolation (so we cannot evaluate examples that use the auxiliary signal ) and does not support past-time operators. It is written in C++ and uses double-precision floating point numbers for time points and signal values. We evaluate the tool using a number of synthetic signals and a number of properties based on the ones described earlier in the paper.
Signals. We use the following signals discretized with time step 1.
, x always eventually becomes stable around some value for 200 time units.
: x always eventually becomes stable around 0 for 200 time units.
, where
, x always eventually becomes stable for at least 200 time units and then starts changing with derivative of at least 0.1.
, every local maximum is followed by a local minimum.
, if x is above 0.85, it should eventually become below
.
, spike of half-width 16 and height at least 0.5.
, where
, spike of width at most 25 and magnitude 0.04.
Some properties are expressed in our language using - and “until”-operators, and some are STL properties. This allows us to see how much time it takes to monitor a more complicated property in our language (e.g.,
, stabilization around an unknown value) compared to a similar but more simple STL property (e.g.,
, stabilization around a known value). In our experiments we see a constant factor between 2 and 5.
Monitoring time for different formulas and signals.
data:image/s3,"s3://crabby-images/48bc4/48bc456303a49a7bb62716a2bc29995ea0c42499" alt="../images/483135_1_En_5_Chapter/483135_1_En_5_Tab1_HTML.png"
6 Conclusion and Future Work
We describe a new specification language that extends STL with the ability to produce and manipulate real-valued output signals (while in STL, every formula has a Boolean output signal). Properties in the new language are specified in terms of minima and maxima over a sliding window, which can have fixed width, when using a generalization of - and
-operators, or variable width, when using a new version “until”. We show how the new language can express properties that motivated the creation of more expressive and harder to monitor logics. Offline monitoring for the new language is almost as efficient as STL monitoring; the complexity is linear in the length of the input signal and does not depend on the constants appearing in the formula.
There are multiple directions for future work; perhaps more interesting one is adding integration over a sliding window (in addition to minimum and maximum). This is already allowed by some formalisms [7], and when added to our language will allow to assert that a signal approximates the behaviour of a system defined by a given differential equation (since we will be able to assert ). Before making integration available, we wish to investigate how to better deal in a specification language with approximation errors. Finally, we wish to make our language usable in falsification, which means that for every formula with Boolean output signal we wish to be able to compute a real-valued robustness measure.
Acknowledgements
The authors thank T. Ferrére, D. Nickovic, E. Asarin for comments on the draft of this paper, and O. Lebeltel for providing a version of AMT for the experiments.
data:image/s3,"s3://crabby-images/6885a/6885a77dd71d254824942958153bdb5500d03cf0" alt="Creative Commons"
Open Access This chapter is licensed under the terms of the Creative Commons Attribution 4.0 International License (http://creativecommons.org/licenses/by/4.0/), which permits use, sharing, adaptation, distribution and reproduction in any medium or format, as long as you give appropriate credit to the original author(s) and the source, provide a link to the Creative Commons license and indicate if changes were made.
The images or other third party material in this chapter are included in the chapter's Creative Commons license, unless indicated otherwise in a credit line to the material. If material is not included in the chapter's Creative Commons license and your intended use is not permitted by statutory regulation or exceeds the permitted use, you will need to obtain permission directly from the copyright holder.