A framework for the elicitation and debugging of formal specifications for Cyber-Physical Systems is presented. The elicitation of specifications is handled through a graphical interface. Two debugging algorithms are presented. The first checks for erroneous or incomplete temporal logic specifications without considering the system. The second can be utilized for the analysis of reactive requirements with respect to system test traces. The specification debugging framework is applied on a number of formal specifications collected through a user study. The user study establishes that requirement errors are common and that the debugging framework can resolve many insidious specification errors.
Formal Requirement Debugging for Testing and Verification of Cyber-Physical Systems 1 INTRODUCTION
Testing and verification of Cyber-Physical Systems (CPSs) is important due to the safety-critical applications of CPSs such as medical devices and transportation systems. It has been shown that utilizing formal specifications can lead to improved testing and verification Jin et al. 2013; Yang et al. 2012; Kapinski et al. 2015) . However, developing formal specifications using logics is a challenging and error-prone task even for experts who have formal mathematical training. Therefore, in practice, system engineers usually define specifications in natural language. Natural language is convenient to use in many stages of system development, but its inherent ambiguity, inaccuracy, and inconsistency make it unsuitable for use in defining specifications.
To assist in the elicitation of formal specifications, in Hoxha et al. (2014b , we presented a graphical formalism and the corresponding tool ViSpec that can be utilized by users in both academia and industry. Namely, a user-developed graphical input is translated to a Metric Interval Temporal Logic (MITL) formula. The formal specifications in MITL can be used for testing and verification with tools such as S-TaLiRo (Annapureddy et al. 2011) and Breach (Donze 2010) .
In , the tool was evaluated through a usability study, which showed that ViSpec users were able to use the tool to elicit formal specifications. The usability study results also indicated that in a few cases, the developed specifications were incorrect. This raised two questions. First, are these issues artifacts of the graphical user interface? Second, can we automatically detect and report issues with the requirements themselves?
We have created an online survey 1 to answer the first question. Namely, we conducted a usability study on MITL by targeting users with working knowledge in temporal logics. In our online survey, we tested how well formal method users can translate natural requirements to MITL. That is, given a set of requirements in natural language, users were asked to formalize the requirements in MITL. The study is ongoing, but preliminary results indicate that even users with working knowledge of MITL can make errors in their specifications.
For example, for the natural language specification "At some time in the first 30 seconds, the vehicle speed (v) will go over 100 and stay above 100 for 20 seconds," the specification φ = [0, 30] ((v > 100) ⇒ [0, 20] (v > 100)) was provided as an answer by a user with formal logic background. Here, [0, 30] stands for "eventually within 30 time units" and [0,20] for "always from 0 to 20 time units." However, the specification φ is a tautology!; i.e., it evaluates to true no matter what the system behavior is and thus the requirement φ is invalid. This is because, if at some time t between 0 and 30 seconds the predicate (v > 100) is false, then the implication (⇒) will trivially evaluate to true at time t and thus φ will evaluate to true as well. On the other hand, if the predicate (v > 100) is true for all times between 0 and 30 seconds, then the subformula [0, 20] (v > 100) will be true at all times between 0 and 10 seconds. This means that the subformula (v > 100) ⇒ [0, 20] (v > 100) is true at all times between 0 and 10 seconds. Thus, again, φ evaluates to true, which means that φ is a tautology.
This implies that specification issues are not necessarily artifacts of the graphical user interface and that they can happen even for users who are familiar with temporal logics. Hence, specification elicitation can potentially become an issue as formal and semiformal testing and verification methods and tools are being adopted by industry. This is because specification elicitation can be performed by untrained users. Therefore, effort can be wasted in checking incorrect requirements, or even worse, the system can pass the incorrect requirements. Clearly, this can lead to a false sense of system correctness, which leads us to the second question: What can be done in an automated way to prevent specification errors in CPS?
In this work, we have developed a specification debugging framework to assist in the elicitation of formal requirements. The specification debugging algorithm identifies some of the logical issues in the specifications, but not all of them. Namely, it performs the following:
Formal Requirement Debugging for Testing and Verification of CPS 34:3 CPS developer find more vacuity issues during system testing. Our framework can help developers correct their specifications as well as find more subtle errors during testing.
This article is an extended version of the conference paper that appeared in MEMOCODE 2015 (Dokhanchi et al. 2015) .
Summary of Contributions:
(1) We present a specification debugging algorithm for a fragment of MITL (Alur et al. 1996) specifications.
(2) Using (1), we provide a debugging algorithm for Signal Temporal Logic Specifications (Maler and Nickovic 2004) . (3) We extend Linear Temporal Logic (LTL) (Clarke et al. 1999 ) vacuity detection algorithms (Chockler and Strichman 2009 ) to real-time specifications in MITL. (4) We formally define signal vacuity and we provide an algorithm to detect the system traces that vacuously satisfy the real-time specifications in MITL. (5) We present experimental results on specifications that typically appear in requirements for CPS.
The above contributions can help us address and solve some of the logical issues that may be encountered when writing MITL specifications. In particular, we believe that our framework will primarily help users with minimal training in formal requirements who use graphical specification formalisms like ViSpec . The users of ViSpec can benefit from our feedback and fix any reported issues. In addition, we can detect potential system-level issues using algorithms to determine specification vacuity with respect to system traces during testing. In this article, the new results over the conference version of the article (Dokhanchi et al. 2015 ) concern item (4) in the list above and are presented in Sections 6, 7.3, and 7.4 and Appendix B. In addition, we have expanded some examples and added further experimental results that did not appear in Dokhanchi et al. (2015) . Furthermore, we added new algorithms in Section 4.
RELATED WORKS
The challenge of developing formal specifications has been studied in the past. The most relevant works appear in Autili et al. (2007) and Zhang et al. (2010) . Autili et al. (2007) extend Message Sequence Charts and UML 2.0 Interaction Sequence Diagrams to propose a scenario-based formalism called a Property Sequence Chart (PSC). The formalism is mainly developed for specifications on concurrent systems. In Zhang et al. (2010) , PSC is extended to Timed PSC, which enables the addition of timing constructs to specifications. Another nongraphical approach to the specification elicitation problem utilizes specification patterns (Dwyer et al. 1998 ). The patterns provided include commonly used abstractions for different logics including LTL, Computation Tree Logic (CTL), or Quantified Regular Expressions (QREs). This work was extended to the real-time domain (Konrad and Cheng 2005) .
Specification debugging can also be considered in areas such as system synthesis (Raman and Kress-Gazit 2011) and software verification (Ammons et al. 2003) . In system synthesis, realizability is an important factor, which checks whether the system is implementable given the constraints (environment) and requirements (specification) (Ehlers and Raman 2014; Könighofer et al. 2013; Cimatti et al. 2008; Raman and Kress-Gazit 2011) . Specification debugging can also be considered with respect to the environment for robot motion planning. Fainekos (2011) and Kim et al. (2012) considered the problem where the original specification is unsatisfiable with the given environment and robot actions. Then they relax the specification in order to render it satisfiable in the given domain.
One of the most powerful verification methods is model checking (Clarke et al. 1999) , where a finite state model of the system is evaluated with respect to a specification. For example, let us consider model checking with respect to the LTL formula φ = (req ⇒ ack ), which represents the following Request-Response requirement: "if at any time in the future a request happens, then from that moment on an acknowledge must eventually happen." Here, φ can be trivially satisfied in all systems in which a request never happens. In other words, if the request never happens in the model of the system (let's say due to a modeling error), our goal for checking the reaction of the system (issuing the acknowledge) is not achieved. Thus, the model satisfies the specification but not in the intended way. This may hide actual problems in the model. Such satisfactions are called vacuous satisfactions. Antecedent failure was the first problem that raised vacuity as a serious issue in verification (Beatty and Bryant 1994; Ben-David et al. 2015) . Vacuity can be addressed with respect to a model (Beer et al. 2001; Kupferman and Vardi 2003) or without a model Chockler and Strichman 2009) . A formula that has a subformula that does not affect the overall satisfaction of the formula is a vacuous formula. It has been proven in that a specification φ is satisfied vacuously in all systems that satisfy it if and only if φ is equivalent to some mutations of it. Chockler and Strichman (2009) provide an algorithmic approach to detecting vacuity and redundancy in LTL specifications. Vacuity with respect to testing was considered in Ball and Kupferman (2008) . Ball and Kupferman (2008) defined weak vacuity for test suites that vacuously pass LTL monitors (e.g., Havelund and Rosu (2004) ). The main idea behind the work in Ball and Kupferman (2008) is that some transitions are removed from the LTL specification automata in order to find vacuous passes during testing. Ball and Kupferman (2008) renamed the vacuity in model checking as strong vacuity. Post et al. (2011) consider the problem of vacuity detection in the set of requirements formalized in Duration Calculus (Meyer et al. 2008) .
Our work extends Chockler and Strichman (2009) and it is applied to a fragment of MITL. We provide a new definition of vacuity with respect to Boolean or real-valued signals. To the best of our knowledge, vacuity of real-time properties such as MITL has not been addressed yet. Although this problem is computationally hard, in practice, the computation problem is manageable, due to the small size of the formulas.
PRELIMINARIES
In this work, we take a general approach in modeling CPSs. In the following, R is the set of real numbers, R + is the set of nonnegative real numbers, Q is the set of rational numbers, and Q + is the set of nonnegative rational numbers. Given two sets A and B, B A is the set of all functions from A to B; i.e., for any f ∈ B A , we have f : A → B. We define 2 A to be the power set of set A. Since we primarily deal with bounded time signals, we fix the variable T ∈ R + to denote the maximum time of a signal.
Metric Interval Temporal Logic
Metric Temporal Logic (MTL) was introduced in Koymans (1990) in order to reason about the quantitative timing properties of Boolean signals. MITL is MTL where the timing constraints are not allowed to be singleton sets (Alur et al. 1996) . In the rest of the article, we restrict our focus to a fragment of MITL called Bounded-MITL( , ), where the only temporal operators allowed are Eventually ( ) and Always ( ) operators with timing intervals. Formally, the syntax of Bounded-MITL( , ) is defined by the following grammar:
where a ∈ AP, AP is the set of atomic propositions, is true, and ⊥ is false. Also, I is a nonsingular interval over Q + with defined endpoints. The interval I is right-closed. We interpret MITL semantics over timed traces. A timed trace is a mapping from the bounded real line to sets of atomic propositions (μ : [0,T ] → 2 AP ). We assume that the traces satisfy the finite variability condition (non-Zeno condition). 2 Definition 3.2 (Bounded-MITL( , ) semantics in Negation Normal Form (NNF)). Given a timed trace μ : [0,T ] → 2 AP and t, t ∈ [0,T ], and an MITL formula ϕ, the satisfaction relation (μ, t ) ϕ is inductively defined as:
In this article, we assume that the Bounded-MITL( , ) formula is in NNF, 3 where the negation operation is only applied on atomic propositions. NNF is easily obtainable by applying DeMorgan's Law, i.e., ¬ I φ ≡ I ¬φ and ¬ I φ ≡ I ¬φ. Any Implication operation (⇒) will be rewritten as ψ ⇒ φ ≡ ψ ∨ φ, where ψ ≡ ¬ψ and also ψ is in NNF, and NNF formulas only contain the following Boolean operators of (∧, ∨). For simplifying the presentation, when we mention MITL, we mean Bounded-MITL( , ). Given MITL formulas φ and ψ , φ satisfies ψ , denoted by φ |= ψ if and only if ∀μ.μ |= φ ⇒ μ |= ψ . Throughout this article, we use φ ∈ ψ to denote that φ is a subformula of ψ .
Signal Temporal Logic
The logic and semantics of MITL can be extended to real-valued signals through Signal Temporal Logic (STL) (Maler and Nickovic 2004) . (Maler and Nickovic 2004) ). Let s : [0,T ] → R m be a realvalued signal, and Π = {π 1 , . . . , π n } be a collection of predicates or Boolean functions of the form
Definition 3.3 (Signal Temporal Logic
For any STL formula Φ ST L over predicates Π, we can define a corresponding MITL formula Φ MIT L over some atomic propositions AP as follows:
(1) Define a set AP such that for each π ∈ Π, there exist some a π ∈ AP.
(2) For each real-valued signal s we define a μ such that ∀t .a π ∈ μ (t ) if and only if π (s (t )) = .
(
The traces resulting from abstractions through predicates of signals from physical systems satisfy the finite variability assumption. For practical applications, the finite variability assumption is satisfied. Since our article focuses on CPS, with the abuse of terminology, we may use signal to refer to both timed traces and signals. Specifications of the form ϕ used to define specifications that, it is always the case, at some point in the future, ϕ repeatedly will become true. Implication
Specifications of the form ϕ ⇒ ψ require that ψ should hold when ϕ is true.
Request-Response
Specifications of the form (ϕ ⇒ Mψ ), where M is temporal operator, used to define an implicative response between two specifications where the timing of M is relative to the timing of . Conjunction Specifications of the form ϕ ∧ ψ used to define the conjunction of two subspecifications. Nonstrict Sequencing Specifications of the form N (ϕ ∧ Mψ ), where N and M are temporal operators, used to define a conjunction between two specifications where the timing of M is relative to the timing of N .
Visual Specification Tool
The Visual Specification Tool (ViSpec) enables the development of formal specifications for CPS. The graphical formalism enables reasoning on both timing and event sequence occurrence. Consider the specification ϕ cps = [0,30] ((speed > 100) ⇒ [0, 40] (rpm > 4000)). It states that whenever, within the first 30 seconds, vehicle speed goes over 100, then from that moment on, the engine speed (rpm), for the next 40 seconds, should always be above 4,000. Here, both the sequence and timing of the events are of critical importance. See Figure 1 for the visual representation of ϕ cps .
Users develop specifications using a visual formalism that can be translated to an MITL formula. The set of specifications that can be generated from this graphical formalism is a proper subset of the set of MITL specifications. Figure 2 represents the grammar that produces the set of formulas that can be expressed by the ViSpec graphical formalism. In Figure 2 , p is an atomic proposition. In the tool, the atomic propositions are automatically derived from graphical templates. For example, the formula I I p can be generated using the following parse tree S−→T−→C−→ I I D−→ I I p. ViSpec provides a variety of templates and the connections between them, which allow the users to express a wide collection of specifications as presented in Table 1 . For a more detailed description of ViSpec, refer to . 
MITL ELICITATION FRAMEWORK
Our framework for elicitation of MITL specifications is presented in Figure 3 . Once a specification is developed using ViSpec, it is translated to STL. Then, we create the corresponding MITL formula from STL. Next, the MITL specification is analyzed by the debugging algorithm, which returns an alert to the user if the specification has inconsistency or correctness issues. The debugging process is explained in detail in the next section.
To enable the debugging of specifications, we must first project the STL predicate expressions (functions) into atomic propositions with independent truth valuations. This is very important because the atomic propositions (a ∈ AP) in MITL are assumed to be independent of each other. However, when we project predicates to the atomic propositions, the dependency between the predicates restricts the possible combinations of truth valuations of the atomic propositions. This notion of predicate dependency is illustrated using the following example. Consider the real-valued signal Speed in Figure 4 . The Boolean abstraction a (b, respectively) over the Speed signal is true when the Speed is above 100 (80, respectively). The predicates a and b are related to each other because it is always the case that if Speed > 100, then also Speed > 80. In Figure 4 , the Boolean signals for predicates a and b are represented in black solid and dotted lines, respectively. It can be seen that solid and dotted lines are overlapping, which shows the dependency between them. However, this dependency is not captured if we naively substitute each predicate with a unique atomic proposition. If we lose information about the intrinsic logical dependency between a and b, then the debugging algorithm will not find possible specification issues.
For analysis of STL formulas within our MITL debugging process, we must replace the original predicate with nonoverlapping (mutual exclusive) predicates. For the example illustrated in Figure 4 , we create a new atomic proposition c that corresponds to 100 ≥ speed > 80 and the corresponding Boolean signal is represented in gray. In addition, we replace the atomic proposition b with the propositional formula a ∨ c since speed > 80 ≡ (speed > 100 ∨ 100 ≥ speed > 80). Now, the dependency between Speed > 100 and Speed > 80 can be preserved because it is always the case that if a (Speed > 100), then a ∨ c (Speed > 80). It can be seen in Figure 4 that the signal b (dotted line) is the disjunction of the solid black (a) and gray (c) signals, where a and c cannot be simultaneously true.
The projection of STL to MITL with independent atomic propositions is conducted using a brute-force approach that runs through all the combinations of predicate expressions to find overlapping parts. The high-level overview of Algorithm 1 is as follows: given the set of predicates Π = {π 1 , . . . , π n }, the algorithm iteratively calls Algorithm 2 (DecPred) in order to identify predicates whose corresponding sets have nonempty intersections. For each predicate π i , we assume there exists a corresponding set S i such that
The set S i represents part of space R m where predicate function π i evaluates to . When no nonempty intersection is found, the Algorithm 1 terminates.
Algorithm 1 creates a temporary copy of Π in a new set Δ. Then in a while-loop Algorithm 2 is called in Line 3 to find overlapping predicates. Algorithm DecPred checks all the combinations of predicates in Δ until it finds overlapping sets (see Line 3). The DecPred partitions two overlapping predicates π i , π j into three mutually exclusive predicates π i j1 , π i j2 , π i j3 in Lines 4 to 6. Then π i , π j are removed from Δ in Line 7 and new predicates π i j1 , π i j2 , π i j3 are appended to Δ (Line 8). If no overlapping predicates are found, then DecPred returns ∅ in Line 13 and termCond gets value 1 in Line 7 of Algorithm 1. Now the while-loop will terminate and Ψ contains all nonoverlapping predicates. We must rewrite the predicates in Π with a disjunction operation on the new predicates in Ψ. This operation takes place in Line 11 of Algorithm 1. Since the function CreateDisjunction is trivial, we omit its pseudo-code. The runtime overhead of Algorithm 1 and the size of the resulting set Ψ can be exponential to |Π| = n, because we can have 2 n possible combinations of predicate evaluations.
ALGORITHM 1: Generate Mutually Exclusive Predicates
Input: Set of predicates Π = {π 1 , . . . , π n } Output: Mutually exclusive predicates Ψ Update Π with Disjunction of predicates Ψ 1: termCond ← 0; Δ ← Π 2: while termCond = 0 do 3:
end if 10: end while 11: Π ←CreateDisjunction(Π, Ψ) 12: return Π,Ψ ALGORITHM 2 : DecPred: Decompose Two Predicates Input: Set of predicates Π = {π 1 , . . . , π n } Output: Set of updated predicates Π 1: for i = 1 to size of Π do 2: 
MITL SPECIFICATION DEBUGGING
In the following, we present algorithms that can detect inconsistency and correctness issues in specifications. This will help the user in the elicitation of correct specifications. Our specification debugging process conducts the following checks in this order: (1) validity, (2) redundancy, and (3) vacuity. In brief, validity checking determines whether the specification is unsatisfiable or a tautology. Namely, if the specification is unsatisfiable, no system can satisfy it, and if it is a tautology, every system can trivially satisfy it. For example, p ∨ ¬p is a tautology. If an MITL formula passes the validity checking, this means that the MITL is satisfiable but not a tautology.
Redundancy checking determines whether the specification has any redundant conjunct. For example, in the specification p ∧ [0,10] p, the first conjunct is redundant. Sometimes redundancy is related to incomplete or erroneous requirements where the user may have wanted to specify something else. Therefore, the user should be notified. Vacuity checking determines whether the specification has a subformula that does not affect the satisfaction of the specification. For example, φ = p ∨ [0,10] p is vacuous since the first occurrence of p does not affect on the satisfaction of φ. This is a logical issue because a part of the specification is overshadowed by the other components.
The debugging process is presented in Figure 5 . The feedback (Revision Necessary) to the user is a textual description about the detail of each issue. First, given a specification, a validity check is conducted. If a formula does not pass the validity check, then it means that there is a major problem in the specification and the formula is returned for revision. Therefore, redundancy and vacuity checks are not relevant at that point and the user is notified that the specification either is unsatisfiable or is a tautology. Similarly, if the specification is redundant, it means that it has a conjunct that does not have any effect on the satisfaction of the specification and we return the redundant conjunct to the user for revision. Lastly, if the specification is vacuous, it is returned with the issue for revision by the user. When vacuity is detected, we return to the user the simplified formula, which is equivalent to the original MITL.
Redundancy Checking
Recall that a specification has a redundancy issue if one of its conjuncts can be removed without affecting the models of the specification. Before we formally present what redundant requirements are, we have to introduce some notation. We consider specification Φ as a conjunction of MITL subformulas (φ j ):
(1)
To simplify discussion, we will abuse notation and we will associate a conjunctive formula with the set of its conjuncts. That is:
Similarly, {Φ\φ i } represents the specification Φ where the conjunct φ i is removed:
ALGORITHM 3: Redundancy Checking
end for 8: end for 9: return R φ ALGORITHM 4: Vacuity Checking
end for 8: end for 9: return V φ Therefore, {Φ\φ i } represents a conjunctive formula. Redundancy in specifications can appear in practice due to the incremental approach that system engineers take in the development of specifications. Redundancy should be avoided in formal specifications because it increases the overhead of the testing and verification processes. In addition, redundancy can be the result of incorrect translation from natural language requirements. In the following, we consider the redundancy removal algorithm provided in Chockler and Strichman (2009) for LTL formulas and we extend it to support MITL formulas.
In addition, [0, 10] p is redundant with respect to [0, 10] [0, 10] p. This method can detect both issues and report them to the user. Algorithm 3 finds redundant conjuncts in the conjunction operation of the following levels:
(1) Conjunction as the root formula (top level) (2) Conjunction in the nested subformulas (lower levels)
In the top level, it provides the list of subformulas that are redundant with respect to the original MITL Φ. In the lower levels, if a specification has nested conjunctive subformulas (ϕ i ∈ Φ), it will return the conjunctive subformula ϕ i as well as its redundant conjunct ψ j ∈ ϕ i . For example, if Φ = [0,10] (p ∧ [0,10] p) is checked by Algorithm 3, then it will return the pair of (p, p ∧ [0,10] p) to represent that p is redundant in p ∧ [0,10] p. In Line 5, the pair of (ψ j , ϕ i ) is interpreted as follows: ψ j is redundant in ϕ i .
Specification Vacuity Checking
Vacuity detection is used to ensure that all the subformulas of the specification contribute to the satisfaction of the specification. In other words, vacuity checking enables the detection of irrelevant subformulas in the specifications (Chockler and Strichman 2009) . For example, consider the STL specification ϕ stl = [0,10] ((speed > 100) ∨ [0,10] (speed > 80)). In this case, the subformula (speed > 100) does not affect the satisfaction of the specification. This indicates that ϕ stl is a vacuous specification. We need to create correct atomic propositions for the predicate expressions of ϕ stl to be able to detect such vacuity issues in MITL formulas. If we naively replace the predicate expressions speed > 100 and speed > 80 with the atomic propositions a and b, respectively, then the resulting MITL formula will be ϕ mitl = [0,10] (a ∨ [0,10] b). However, ϕ mitl is not vacuous. Therefore, we must extract nonoverlapping predicates as explained in Section 4. The new specification ϕ mitl = [0,10] (a ∨ [0,10] (a ∨ c)), where a corresponds to speed > 100 and c corresponds to 100 ≥ speed > 80, is the correct MITL formula corresponding to ϕ stl , and it is vacuous. In the following, we provide the definition of MITL vacuity with respect to a signal:
Definition 5.2 (MITL Vacuity with Respect to Timed Trace). Given a timed trace μ and an MITL formula φ, a subformula ψ of φ does not affect the satisfiability of φ with respect to μ if and only if ψ can be replaced with any subformula θ without changing the satisfiability of φ on μ. A specification φ is satisfied vacuously by μ, denoted by μ |= V φ, if there exists a subformula ψ that does not affect the satisfiability of φ on μ.
In the following, we extend the framework presented in Chockler and Strichman (2009) to support MITL specifications. Let φ be a formula in NNF where only predicates can be in the negated form. A literal is defined as a predicate or its negation. For a formula φ, the set of literals of φ is denoted by literal (φ) and contains all the literals appearing in φ. For example, if φ = (¬p ∧ q) ∨ [0,10] p ∨ [0,10] q, then literal (φ) = {¬p, q, p}. Literal occurrences, denoted by litOccur (φ), are a multiset of literals appearing in some order in φ, e.g., by traversal of the parse tree. For the given example, litOccur (φ) = {¬p, q, p, q}. For each l ∈ litOccur (φ), we create the mutation of φ by substituting the occurrence of l with ⊥. We denote the mutated formula as φ[l ←⊥]. 
Theorem 5.4 (MIT L Inherent Vacuity). Assume that the specification Φ is a conjunction of MITL formulas. If ∃φ i ∈ Φ and ∃l ∈ litOccur (φ i ), such that Φ |= φ i [l ←⊥], then Φ is inherently vacuous.
A specification Φ is inherently vacuous if it is equivalent to its simplified mutation, which means that Φ is vacuous independent of any signal or system. Inherent vacuity of LTL formulas is addressed in and Chockler and Strichman (2009) . The proof of Theorem 5.4 is a straightforward modification of the proofs given in Chockler and Strichman (2009) and Kupferman and Vardi (2003) . For completeness in the presentation, we provide the proof in Appendix A. When we do not have a root-level conjunction in the specification (Φ = φ 4 ), we check the vacuity of the formula with respect to itself. In other words, we check whether the specification satisfies its mutation (φ |= φ[l ←⊥]). Technically, Algorithm 4 as presented returns a list of all the mutated formulas that are equivalent to the original MITL.
SIGNAL VACUITY CHECKING
In the previous section, we addressed specification vacuity without considering the system. However, in many cases, specification vacuity depends on the system. For example, consider the 34:12 A. Dokhanchi et al. In the first 40 seconds, vehicle speed should always be less than 160.
Reachability
In the first 30 seconds, vehicle speed should go over 120.
Stabilization
At some point in time in the first 30 seconds, vehicle speed will go over 100 and stay above for 20 seconds.
Oscillation
At every point in time in the first 40 seconds, vehicle speed will go over 100 in the next 10 seconds.
It is not the case that, for up to 40 seconds, the vehicle speed will go over 100 in every 10-second period. 6. Implication
If, within 40 seconds, vehicle speed is above 100, then within 30 seconds from time 0, engine speed should be over 3,000. LTL specification φ = (req ⇒ ack ). The specification φ does not have an inherent vacuity issue ). However, if req never happens in any of the behaviors of the system, then the specification φ is vacuously satisfied on this specific system. As a result, it has been argued that it is important to add vacuity detection in the model checking process (Beer et al. 2001; Kupferman and Vardi 2003) . We encounter the same issue when we test signals and systems with respect to Request-Response STL/MITL specifications.
Vacuous Signals
Consider the MITL specification φ = [0,5] (req ⇒ [0,10] ack ). This formula will pass the MITL Specification Debugging method presented in Section 5. However, any timed trace μ that does not satisfy req at any point in time during the test will vacuously satisfy φ. We refer to timed traces that do not satisfy the antecedent (precondition) of the subformula as vacuous timed traces. Similarly, these issues follow for STL formulas over signals as well. Consider Task 6 in Table 2 with the specification ψ = [0,40] (speed > 100) ⇒ [0,30] (rpm > 3000). Any real-valued signal s that does not satisfy [0, 40] (speed > 100) will vacuously satisfyψ . Finding such signals is important in testing and monitoring, since if a signal s does not satisfy the precondition of an STL/MITL specification, then there is no point in considering s as a useful test.
Definition 6.1 (Vacuous Timed Trace (Signal)). Given an MITL (STL) formula φ, a timed trace μ (signal s) is vacuous if it satisfies the Antecedent Failure mutation of φ.
Antecedent Failure is one of the main sources of vacuity. Antecedent Failure occurs in a Request-Response specification such as φ RR = [0,5] (req ⇒ [0,10] ack ). We provide a formula mutation that can detect signal vacuity in Request-Response specifications.
Definition 6.2 (Request-Response MITL). A Request-Response MITL formula φ RR is an MITL formula that has one or more implication (⇒) operations in positive polarity (without any negation). In addition, for each implication operation, the consequent must have a temporal operator at the top level.
In the Request-Response (RR) specifications (Horn et al. 2015) , we define sequential events in a specific order (by using the implication operator). Many practical specification patterns based on the Request-Response format are provided for system properties (Dwyer et al. 1998; Konrad and Cheng 2005) . Therefore, we can define a chain of events that the system must respond/react to. In an RR specification such as φ RR = [0,5] (req ⇒ [0,10] ack ), the temporal operator for the consequent [0, 10] ack is necessary, unless the system does not have any time to acknowledge the req. For any trace μ in which req never happens, we can substitute ack by any formula and the specification is still satisfied by μ. Therefore, if the antecedent is failed by a trace μ, then φ RR is vacuously satisfied by μ. For each implication subformula (φ ⇒ ψ ), the left operand (φ) is the precondition (antecedent) of the implication. An antecedent failure mutation is a new formula that is created with the assertion that the precondition (φ) never happens. Note that RR specifications should not be translated into NNF. For each precondition φ, we create an antecedent failure mutation I φ (¬φ), where I φ is called the effective interval of φ. Definition 6.3 (Effective Interval). The effective interval of a subformula is the time interval when the subformula can have an impact on the truth value of the whole MITL (STL) specification.
Each subformula is evaluated only in the time window that is provided by the effective interval. For example, for the MITL specification φ ∧ ψ , the effective interval for both φ and ψ is [0,0], because φ andψ can change the value of φ ∧ ψ only within the interval [0,0]. Similarly, for the MITL specification [0, 10] φ, the effective interval of φ is [0,10], since the truth value of φ is observed in the time window of [0,10] for evaluating [0, 10] φ. The effective interval is important for the creation of an accurate antecedent failure mutation. This is because the antecedent can affect the truth value of the MITL formula only if it is evaluated in the effective interval. The effective interval is like a time window to make the antecedent observable for an outside observer the way it is observed by the MITL specification. The effective interval of MITL formulas can be computed recursively using Algorithm 5. To run Algorithm 5, we must process the MITL formula parse tree. 5 The algorithm must be initialized with the interval of [0,0] for the top node of the MITL formula, namely, EIU(φ,[0,0]). This is because, 5 We assume that the MITL specification is saved in a binary tree data structure where each node is a formula with the left/right child as the left/right corresponding subformula of φ. In addition, we assume that the nodes of φ's tree contain a field called EI , where we annotate the effective interval of φ in EI , namely, φ .EI ← I φ .
according to the semantics of MITL, the value of the whole MITL formula is only important at time zero. In Line 8 of Algorithm 5, the operator ⊕ is used to add two intervals as follows: 6 In Line 1 of Algorithm 5, the input interval I is assigned to the effective interval of φ, namely, φ.EI . If the top operation of φ is a propositional operation (¬, ∨, ∧, ⇒), then the I will be propagated to subformulas of φ (see Lines 2-6). If the top operation of φ is a temporal operator ( I , I ), then the effective interval is modified according to Definition 6.4 and the interval I ← I ⊕ I is propagated to the subformulas of φ. For example, assume that the MITL specifi- 4, 6] (c ⇒ [0,2] d ))). The specification φ has two antecedents, α 1 = [3, 5] b and α 2 = c. The effective intervals of α 1 and α 2 are I α 1 = [0, 0] ⊕ [1, 2] = [1, 2] and I α 2 = [0, 0] ⊕ [1, 2] ⊕ [4, 6] = [5, 8], respectively. As a result, the antecedent failure mutations are [1, 2] (¬ [3, 5] b) and [5, 8] (¬c), respectively. Algorithm 6 returns the list of antecedent failures AF φ , namely, all the vacuously satisfied implication subformulas by s. If the AF φ list is empty, then the signal s is not vacuous. To check whether the signal s satisfies φ's mutations in Algorithm 6 (Line 5), we should use an offline monitor such as .
ALGORITHM 6: Antecedent Failure
Input: φ RR ,s (RR Specification, Signal) Output: AF φ a list of failed antecedents 1: end for 8: end for 9: return MF φ
Vacuity Detection in Testing and Falsification
Detecting vacuous satisfaction of specifications is usually applied on top of model checking tools for finite-state systems (Beer et al. 2001; Kupferman and Vardi 2003) . However, in general, the verification problem for hybrid automata (a mathematical model of CPS) is undecidable (Alur et al. 1995) . Therefore, a formal guarantee about the correctness of CPS modeling and design is impossible, in general. CPSs are usually safety-critical systems and the verification and validation of these systems is necessary. One approach is to use Model-Based Design (MBD) with a mathematical model of the CPS to facilitate the system analysis and implementation (Abbas et al. 2013) . Thus, semiformal verification methods are gaining popularity (Kapinski et al. 2015) . Although we cannot solve the correctness problem with testing and monitoring, we can detect possible errors with respect to STL requirements.
In Figure 6 , a testing approach for signal vacuity detection is presented. The input generator creates initial conditions and inputs to the system under test. The system under test can be a Model, Processor in the Loop (PiL), Hardware in the Loop (HiL), or real system. An example of a test generation technology that implements the architecture in Figure 6 is presented in Abbas et al. (2013) . The system under test is simulated to generate an output trace. Then, a monitor checks the trace with respect to the specification and reports to the user whether the system trace satisfies or falsifies the specification (e.g., Maler and Nickovic (2004) ). For each falsification, we will report to the user the falsifying trajectory to investigate the system for this error. Falsification-based approaches for CPS can help us find subtle bugs in industrial-size control systems (Jin et al. 2013 ). If after using stochastic-based testing and numerical analysis we cannot find any bugs, then we are more confident that the system works correctly. However, it will be concerning if the numerical analysis is mostly based on vacuous signals. This is because vacuous signals satisfy the specification for reasons other than what was originally intended. Signal vacuity checking is conducted in Figure 6 using Algorithm 6, and vacuous signals are reported to the user for further inspection. This will help users to focus their analysis on the part of the system that generates vacuous signals to prevent vacuous test generation.
Detecting Partially Covering Signals.
A problem closely related to vacuity detection is the partial coverage problem. In this section, we show that Literal Occurrence Removal can be used for determining partially covering signals. Partially covering signals are the signals that not only satisfy the specification but also satisfy Literal Occurrence Removal mutation: Definition 6.5 (Partially Covering Timed Trace (Signal)). Given an MITL (STL) formula φ in NNF, a timed trace μ (signal s) is partially covering if it satisfies the Literal Occurrence Removal mutation of φ. This mutation is generated by repeatedly substituting the occurrences of literals with ⊥, which is denoted by φ[l ←⊥] (see Definition 5.3). In Algorithm 7, we check whether the signal will satisfy the mutated specification (φ i [l ←⊥]). In the following, we prove that all satisfying signals are also partially covering signals: Theorem 6.6. For all MITL formulas φ ∈ Φ in NNF, if there exists a disjunction subformula in φ, then for all μ such that μ |= φ, it is always the case that there exists a literal l ∈ litOccur (φ) s.t.
The proof of Theorem 6.6 is provided in Appendix B. For any MITL (STL) specification φ that contains one or more disjunction operators (∨) in NNF, any timed trace (signal) that satisfies φ will also satisfy a mutation φ[l ←⊥] for some literal occurrence l. Further, any specification that lacks a disjunction operator (∨) in its NNF will not satisfy φ[l ←⊥] for any literal occurrence l. That is, for formulas without any disjunction operator in NNF, we have φ[l ←⊥] ≡⊥ since for any MITL formula φ, we have φ ∧ ⊥ ≡ ⊥. If all satisfying signals are partially covering signals, what is the benefit of Algorithm 7? There are two applications for Algorithm 7 as follows.
First, Algorithm 7 can find which (how many) disjuncts are satisfied by the partially covering signal. This information can be used by the falsification technique to find the disjuncts/predicates that cause the formula satisfaction. Therefore, the falsification method will target the system behaviors corresponding to those predicates. As a result, Algorithm 7 can be used to improve the falsification method.
Second, Algorithm 7 can also be used for coverage analysis when falsification occurs. This is because with a slight modification, the dual of Algorithm 7 can help us to find the source of the falsification. According to Corollary B.2, for any φ in NNF, where φ has a conjunctive subformula
]. Now, we can identify which conjunct of ψ contributes toward the falsification by substituting it by iteratively applying φ[l ←
]. This can be better explained in the following example:
Example 6.7. Assume φ = I 1 (a ∧ I 2 b) and a falsifying trace μ |= φ exists. Formula φ contains conjunction of ψ = a ∧ I 2 b and litOccur (ψ ) = {a, b}. We can substitute a and b with to find the main source of falsification of φ as follows:
As a result, the dual of Algorithm 7 can be used to debug a trace when the counter example is created using falsification methodologies (Abbas et al. 2013) .
EXPERIMENTAL ANALYSIS
All three levels of the correctness analysis of MITL specifications need satisfiability checking as the underlying tool (Bersani et al. 2013) . In validity checking, we simply check whether the specification and its negation are satisfiable. In general, in order to check whether φ |= ψ , we should check whether φ ⇒ ψ is a tautology, that is, ∀μ, μ |= φ ⇒ ψ . This can be verified by checking whether ¬(φ ⇒ ψ ) is unsatisfiable. Recall that φ ⇒ ψ is equivalent to ¬φ ∨ ψ . So we have to check whether φ ∧ ¬ψ is unsatisfiable to conclude that φ |= ψ . We use the above reasoning for redundancy checking as well as for vacuity checking. For redundancy checking of conjuncts at the root level, {Φ\φ i } ∧ ¬φ i should be unsatisfiable, in order to conclude that {Φ\φ i } |= φ i . For vacuity checking, Φ ∧ ¬(φ i [l ←⊥]) should be unsatisfiable, in order to prove that Φ |= φ i [l ←⊥].
MITL Satisfiability
The satisfiability problem of MITL is EXPSPACE-complete (Alur et al. 1996) . In order to check whether an MITL formula is satisfiable, we use two publicly available tools: qtlsolver 7 and zot. 8 The qtlsolver that we used translates MITL formulas into CLTL-over-clocks (Bersani et al. 2016 (Bersani et al. , 2013 . Constraint LTL (CLTL) is an extension of LTL where predicates are allowed to be assertions on the values of non-Boolean variables (Demri and D'Souza 2007) . That is, in CLTL, we are allowed to define predicates using relational operators for variables over domains like N and Z. Although (Demri and D'Souza 2007) . CLTLoc (CLTL-over-clocks) is a variant of CLTL where the clock variables are the only arithmetic variables that are considered in the atomic constraints. It has been proven in Bersani et al. (2014) that CLTLoc is equivalent to timed automata (Clarke et al. 1999) . Moreover, it can be polynomially reduced to decidable Satisfiability Modulo Theories that are solvable by many SMT solvers such as Z3. 9 The satisfiability of CLTLoc is PSPACE-complete (Bersani et al. 2013 ) and the translation from MITL to CLTLoc in the worst case can be exponential (Bersani et al. 2016) . Some restrictions must be imposed on the MITL formulas in order to use the qtlsolver (Bersani et al. 2016) . That is, the lower bound and upper bound for the intervals of MITL formulas should be integer values and the intervals are left/right closed. Therefore, we expect the values to be integer when we analyze MITL formulas. The high-level architecture of the MITL SAT solver, which we use to check the three issues, is provided in Figure 7 .
Specification Debugging Results
We utilize the debugging algorithm on a set of specifications developed as part of a usability study for the evaluation of the ViSpec tool . The usability study was conducted on two groups:
(1) Group A: These are users who declared that they have little to no experience in working with requirements. The Group A cohort consists of 20 subjects from the academic community at Arizona State University. Most of the subjects have an engineering background. (2) Group B: These are users who declared that they have experience working with system requirements. Note that they do not necessarily have experience in writing requirements using formal logics. The Group B subject cohort was composed of 10 subjects from industry in the Phoenix metro area. Each subject received a task list to complete. The list contained 10 tasks related to automotive system specifications. Each task asked the subject to formalize a natural language specification through ViSpec and generate an STL specification. The task list is presented in Table 2 . A detailed report on the accuracy of the users' response to each natural language requirement is provided in . Note that the specifications were preprocessed and transformed from the original STL formulas to MITL in order to run the debugging algorithm. For example, specification ϕ 3 in Table 3 originally are mapped into atomic propositions with nonoverlapping predicates (Boolean functions) p 1 , p 2 , p 3 . The predicates p 1 , p 2 , p 3 correspond to the following STL representations: p 1 ≡ speed > 100, p 2 ≡ rpm > 4,000, and p 3 ≡ 100 ≥ speed > 80. In Table 3 , we present the common issues with the elicited specifications that our debugging algorithm detects. Note that validity, redundancy, and vacuity issues are present in the specifications listed. It should be noted that for specification ϕ 3 , although finding the error takes a significant amount of time, our algorithm can be used offline.
In Figure 8 , we present the runtime overhead of the three-stage debugging algorithm over specifications collected in the usability study. In the first stage, 87 specifications go through validity checking. Five specifications fail the test and therefore they are immediately returned to the user. As a result, 82 specifications go through redundancy checking of conjunction in the root level, 10 where nine fail the test. Lastly, 73 specifications go through vacuity checking, where five specifications have vacuity issues. The remaining 68 specifications passed the tests. Note that in the figure, two outlier data points are omitted from the vacuity subfigure for presentation purposes. The two cases were timed at 39,618sec and 17,421sec. In both cases, the runtime overhead was mainly because the zot software took hours to determine that the modified specification is unsatisfiable (both specifications were vacuous). The overall runtime of ϕ 3 in Table 3 is 39,645sec, which includes the runtime of validity and redundancy checking. The runtime overhead of vacuity checking of ϕ 3 can be reduced by half because, originally, in vacuity checking we run MITL satisfiability checking for all literal occurrences. In particular, ϕ 3 has four literal occurrences where for two cases zot took more than 19,500sec to determine that the modified specification is unsatisfiable. We can provide an option for early detection: stop and report as soon as an issue is found (the first unsatisfiability).
Formal Requirement Debugging for Testing and Verification of CPS
34:19
The circles in Figure 8 represent the timing performance in each test categorized by the number of literal occurrences and temporal operators. The asterisks represent the mean values and the dashed line is the linear interpolation between them. In general, we observe an increase in the average computation time as the number of literal occurrences and temporal operators increases. All the experimental results in Section 7 were performed on an Intel Xeon X5647 (2.993GHz) with 12GB RAM.
LTL Satisfiability
In the previous section, we mentioned that MITL satisfiability is a computationally hard problem. However, in practice, we know that LTL satisfiability is solvable faster than MITL satisfiability (Li et al. 2013) . In this section, we consider how we can use the satisfiability of LTL formulas to decide about the satisfiability of MITL formulas. Consider the following fragments of MITL and LTL in NNF:
For the always ( ) operator, satisfiability is the dual of the eventually operator ( ). Assume that ϕ M ∈ MITL( ) contains only the operator and ϕ L ∈ LTL( ) is the LTL version of ϕ M . If ϕ L is satisfiable, then ϕ M will also be satisfiable.
Based on the above discussion, if the specification that we intend to test/debug belongs to either category (fragment), MITL( ) or MITL( ), then we can check the satisfiability of its LTL version (ϕ L ) and decide according to the following: Theorem 7.1. For any formula ϕ M ∈ MITL( ) and ϕ M ∈ MITL( ) then:
In these two cases, we do not need to run MITL SAT if otherwise we must apply MITL SAT, which means that we wasted effort by checking LTL SAT. However, since the runtime of LTL SAT is negligible, it will not drastically reduce the performance. As a result, LTL satisfiability checking is useful for validity testing. For redundancy checks, it may also be useful. For example, if we have a formula ϕ = [0,10] p ∧ [0, 20] p, we should check the satisfiability of ϕ = [0,10] ¬p ∧ [0, 20] p and ϕ = [0,10] p ∧ [0, 20] ¬p for redundancy. Although the original formula ϕ does not belong to either MITL( ) or MITL( ), its modified NNF version will fit in these fragments and we may benefit by the usually faster LTL satisfiability for ϕ and/or ϕ . For vacuity checking, we can use LTL satisfiability if, after manipulating/simplifying the original specification and creating the NNF version, we can categorize the resulting formula into the MITL( ) or the MITL( ) fragments (see Table 4 ).
We can check LTL satisfiability of the modified MITL specifications using existing methods and tools (Rozier and Vardi 2010) . In our case, we used the NuSMV 11 tool with a similar encoding of LTL formulas as in Rozier and Vardi (2010) . In Table 4 , we compare the runtime overhead of MITL and LTL satisfiability checking. For the results of the usability study in , we conduct validity and vacuity checking with the LTL satisfiability solver. We remark that in our results in Table 4 , all the formulas belong to the MITL( ) fragment. Since we did not find any MITL( ) formula in our experiments where its LTL version is not satisfiable, we did not provide MITL( ) formulas in Table 4 . The first column of Table 4 provides the debugging test phase where we used the satisfiability checkers. The second column represents the MITL formulas that we tested using the SAT solver. We omit the LTL formulas from Table 4 , since they are identical to MITL but do not contain timing intervals. The atomic propositions p 1 , p 2 , p 3 , p 4 , p 5 of the MITL formulas in Table 4 correspond to the following STL predicates: p 1 ≡ speed > 100, p 2 ≡ rpm > 4,000, p 3 ≡ 100 ≥ speed > 80, p 4 ≡ rpm > 3, 000, and p 5 ≡ speed > 80. The third and fourth columns represent the runtime overhead of satisfiability checking for MITL specifications and their corresponding LTL version. The last column represents the speedup of the LTL approach over the MITL approach. It can be seen that the LTL SAT solver (NuSMV) is about 30 to 300 times faster than the MITL SAT solver (zot). These results confirm that, when applicable, LTL SAT solvers outperform MITL SAT solvers in checking vacuity and validity issues in specifications. As a result, it is worth running LTL SAT before MITL SAT when it is possible.
Antecedent Failure Detection
To apply signal vacuity checking, we use the S-TaLiRo testing framework (Abbas et al. 2013; Hoxha et al. 2014b ). S-TaLiRo is a MATLAB toolbox that uses stochastic optimization techniques to search for system inputs for Simulink models that falsify the safety requirements presented in MTL/STL (Abbas et al. 2013 ). The signal vacuity checking implemented in the S-TaLiRo tool is computationally efficient (PTIME). Its time complexity is proportional to the number of implication operations, the size of the formula, and the size of the signal ).
In the following, we illustrate the vacuous signal detection process by using the Automatic Transmission (AT) model provided by Mathworks as a Simulink demo. 12 We introduced a few modifications to the model to make it compatible with the S-TaLiRo framework. Further details can be found in Hoxha et al. (2014a) . S-TaLiRo calls the AT Simulink model in order to generate the output trajectories. The outputs contain two continuous-time real-valued signals: the speed of the engine ω (RPM) and the speed of the vehicle v. In addition, the outputs contain one continuoustime discrete-valued signal дear with four possible values (дear = 1, . . . ,дear = 4), which indicates There should be no transition from gear two to gear [0,27.5] ((д 2 ∧ (0,0.04] д 1 ) ⇒ [0,2.5] ¬д 2 ) one and back to gear two in less than 2.5sec.
After shifting into gear one, there should be no shift [0,27.5] ((¬д 1 ∧ (0,0.04] д 1 ) ⇒ [0,2.5] д 1 ) from gear one to any other gear within 2.5sec.
If the ω is always less than 4,500, then the v cannot [0, 30] (ω ≤ 4500) ⇒ [0, 10] (v ≤ 85) exceed 85 in less than 10sec.
Within 10sec, v is less than 80 and from that point [0, 10] ((v ≤ 80) ⇒ [0, 30] (ω ≤ 4500)) on, ω is always less than 4,500. the current gear in the auto-transmission controller. S-TaLiRo then monitors system trajectories with respect to the requirements provided in Table 5 . There, in the MITL formulas, we use the shorthand д i to indicate the gear value, i.e., (дear = i) ≡ д i . The simulation time for the system is set to 30 seconds; therefore, we can use bounded MITL formulas for the requirements. After testing the AT with S-TaLiRo, we collected all the system trajectories. Then, we utilized the antecedent failure mutation on the specification to check signal vacuity (Algorithm 6) for each of the formulas that are provided in Table 5 . We provide the antecedent failure specifications and the number of signals that satisfy them in Table 6 . It can be seen in Table 6 that most of the system traces are vacuous signals where the antecedent is not satisfied. This helps the users to consider these issues and identify interesting test cases that can be used to initialize the system tester so that the antecedent is always satisfied. For an application of signal vacuity checking in falsification, see Dokhanchi et al. (2017) .
CONCLUSION AND FUTURE WORK
We have presented a specification elicitation and debugging framework that can assist ViSpec users to produce correct formal specifications. In particular, the debugging algorithm enables the detection of logical inconsistencies in MITL and STL specifications. Our algorithm improves the elicitation process by providing feedback to the users on validity, redundancy, and vacuity issues. In the future, the specification elicitation and debugging framework will be integrated in the ViSpec tool to simplify MITL and STL specification development for verification of CPS. In addition, we considered vacuity detection with respect to signals. This enables improved analysis since some issues can only be detected when considering both the system and the specification. In the future, we will consider the feasibility of using vacuous signals to improve the counterexample generation process and system debugging using signal vacuity.
APPENDIX A PROOF OF THEOREM 5.4
In order to show that Φ is inherently vacuous, we must show that if Φ |= φ i [l ←⊥], then the mutated specification is equivalent to the original specification. In other words, we should show that B PROOF OF THEOREM 6.6 In this section, we will prove that any MITL (STL) φ ∈ Φ that contains a disjunction operation (∨) in NNF can be satisfied by partially covering signals. In other words, we will prove that any timed trace (signal) that satisfies φ will be considered as a partially covering timed trace (signal) according to Algorithm 7. Without loss of generality, we assume that both operands of disjunction are not constant. This is because if one of the operands is equivalent to or ⊥, then the disjunction can be semantically removed as follows ψ ∨ ≡ or ψ ∨ ⊥≡ ψ for any MITL (STL) ψ .
Let us consider the partially covering timed trace (signal) returned by Algorithm 7. If there exist φ i ∈ Φ and l ∈ litOccur (φ i ) such that the timed trace μ satisfies φ i [l ←⊥], then μ will be reported as a partially covering timed trace (signal). Recall that we assume that Φ is a conjunction of MITL specifications according to Equation (1). We also assume that the conjunct φ i ∈ Φ is the MITL subformula that contains the disjunction operation, namely, that ψ = ψ 1 ∨ ψ 2 is a subformula of φ i . Theorem B.1. Any timed trace μ that satisfies φ i will satisfy φ i [l ←⊥] for some l ∈ litOccur (φ i ).
Proof. We have two cases for μ |= φ i and ψ ∈ φ i where ψ = ψ 1 ∨ ψ 2 :
(1) ∀t, (μ, t ) |= ψ : In this case, ψ does not affect the satisfaction of μ |= φ i . If we choose l ∈ litOccur (ψ ), then ψ [l ←⊥] also does not affect the satisfaction of φ i .
(2) ∃t, s.t. (μ, t ) |= ψ : In this case, ψ affects the satisfaction of φ i . So either (μ, t ) |= ψ 1 or (μ, t ) |= ψ 2 . If (μ, t ) |= ψ 1 , then we can choose l ∈ litOccur (ψ 2 ) and we have (μ, t ) |= ψ 1 ∨ ψ 2 [l ←⊥]. Similarly, if (μ, t ) |= ψ 2 , then we can choose l ∈ litOccur (ψ 1 ) and we have (μ, t ) |= ψ 1 [l ←⊥] ∨ ψ 2 . As a result, there exists some l ∈ litOccur (ψ ) where (μ, t ) |= ψ [l ←⊥] and accordingly μ |= φ i [l ←⊥].
Finally, ∀μ, μ |= φ i ∃l ∈ litOccur (φ i ) s.t. μ |= φ i [l ←⊥], which means that μ is a partially covering timed trace (signal). Corollary B.2. Assume that the conjunct φ j ∈ Φ is the subformula that contains the conjunction operation in NNF, namely, that ψ = ψ 1 ∧ ψ 2 is a subformula of φ j . Any timed trace μ that falsifies φ j will falsify φ j [l ← ] for some l ∈ litOccur (φ j ).
C PROOFS OF THEOREM 7.1
We consider two MITL( , ) fragments, denoted MITL( ) and MITL( ). In this proof, we assume that all formulas are in NNF. We also consider LTL( , ) as the set of LTL formulas (with continuous semantics) that contains only and as temporal operators. In the following, we provide the continuous semantics of LTL( , ) over traces with bounded duration. Semantics of LTL( , ) over bounded timed traces can be defined as follows:
Definition C.1 (LTL( , ) continuous semantics). Given a timed trace μ : [0,T ] → 2 AP and t, t ∈ R, and an LTL( , ) formula ϕ, the satisfaction relation (μ, t ) ϕ for temporal operators is inductively defined: We will consider two LTL( , ) fragments denoted LTL( ) and LTL( ). The syntax of MITL and LTL fragments are as presented in Section 7.3. We define the operator [ϕ] LT L , which can be applied to any MITL( , ) formula and removes its interval constraints to create a new formula in LTL( , ). For example, if ϕ = [0,10] (p ∧ q) ∧ [0,10] p ∧ [0,10] q, then [ϕ] LT L = (p ∧ q) ∧ p ∧ q. As a result, for any ϕ ∈ MITL( , ) there exists a ψ ∈ LTL( , ) where ψ = [ϕ] LT L . For each MITL( , ) formula ϕ, the language of ϕ denoted L(ϕ) is the set of all timed traces that satisfy ϕ: μ ϕ if and only if μ ∈ L(ϕ). Similarly, for any ψ ∈ LTL( , ), the language of ψ denoted L(ψ ) is the set of all timed traces that satisfy ψ : μ ψ if and only if μ ∈ L(ψ ). Based on set theory, it is trivial to prove that A ⊆ B and C ⊆ D implies A ∪ C ⊆ B ∪ D and A ∩ C ⊆ B ∩ D.
Theorem C.2. For any formula φ ∈ MITL( ), and t ∈ [0,T ], we have L t (φ) ⊆ L t ([φ] LT L ), where L t (φ) = {μ | (μ, t ) φ}. In other words, for every timed trace μ, we have that (μ, t ) φ implies (μ, t ) [φ] LT L .
Proof. We use structural induction to prove that L t (φ) ⊆ L t ([φ] LT L ). Base Case: if φ = , ⊥, p, ¬p, then [φ] LT L = φ and L t (φ) ⊆ L t ([φ] LT L ). Induction Hypothesis: We assume that there exist φ 1 , φ 2 ∈ MITL( ) where for all t ∈ [0,T ], L t (φ 1 ) ⊆ L t ([φ 1 ] LT L ) and L t (φ 2 ) ⊆ L t ([φ 2 ] LT L ).
Case 1: For binary operators ∧, ∨, we can use the union and intersection properties. In essence, for all formulas φ 1 , φ 2 , we have L t (φ 1 ∨ φ 2 ) = L t (φ 1 ) ∪ L t (φ 2 ) and L t (φ 1 ∧ φ 2 ) = L t (φ 1 ) ∩ L t (φ 2 ). According to the IH, L t (φ 1 ) ⊆ L t ([φ 1 ] LT L ) and L t (φ 2 ) ⊆ L t ([φ 2 ] LT L ); therefore, L t (φ 1 )
