Abstract
In Barringer et al. (2004,Vol. 2937, LNCS), Eagle was introduced as a general purpose rule-based temporal logic for specifying run-time monitors. A novel interpretative trace-checking scheme via stepwise transformation of an Eagle monitoring formula was defined and implemented. However, even though Eagle presents an elegant formalism for the expression of complex trace properties, Eagle's interpretation scheme is complex and appears difficult to implement efficiently. In this article, we introduce RuleR, a primitive conditional rule-based system, which has a simple and easily implemented algorithm for effective run-time checking, and into which one can compile a wide range of temporal logics and other specification formalisms used for run-time verification. As a formal demonstration, we provide a translation scheme for linear-time propositional temporal logic with a proof of translation correctness. We then introduce a parameterized version of RuleR, in which rule names may have rule-expression or data parameters, which then coincides with the same expressivity as Eagle with data arguments. RuleR with just rule-expression parameters extend the expressiveness of RuleR strictly beyond the class of context-free languages. For the language classes expressible in propositional RuleR, the addition of rule-expression and data parameters enables more compact translations. Finally, we outline a few simple syntactic extensions of 'core' RuleR that can lead to further conciseness of specification but still enabling easy and efficient implementation. © The Author, 2010. Published by Oxford University Press. All rights reserved.
Original language | English |
---|---|
Pages (from-to) | 675-706 |
Number of pages | 31 |
Journal | Journal of Logic and Computation |
Volume | 20 |
Issue number | 3 |
DOIs | |
Publication status | Published - Jun 2010 |
Keywords
- Grammars
- Rule systems
- Run-time verification
- Temporal logic