A symbolic model for timed concurrent constraint programming

Abstract : Concurrent Constraint Programming (ccp) is a model for concurrency where agents interact with each other by telling and asking constraints (i.e., formulas in logic) into a shared store of partial information. The ntcc calculus extends ccp with the notion of discrete time-units for the specification of reactive systems. Moreover, ntcc features constructors for non-deterministic choices and asynchronous behavior, thus allowing for (1) synchronization of processes via constraint entailment during a time-unit and (2) synchronization of processes along time-intervals. In this paper we develop the techniques needed for the automatic verification of ntcc programs based on symbolic model checking. We show that the internal transition relation, modeling the behavior of processes during a time-unit (1 above), can be symbolically represented by formulas in a suitable fragment of linear time temporal logic. Moreover, by using standard techniques as difference decision diagrams, we provide a compact representation of these constraints. Then, relying on a fixpoint characterization of the timed constructs, we obtain a symbolic model of the observable transition (2 above). We prove that our construction is correct with respect to the operational semantics. Finally, we introduce a prototypical tool implementing our method.
Liste complète des métadonnées

Cited literature [23 references]  Display  Hide  Download

Contributor : Arias Jaime <>
Submitted on : Tuesday, September 22, 2015 - 2:57:20 PM
Last modification on : Tuesday, April 2, 2019 - 1:45:43 AM
Document(s) archivé(s) le : Tuesday, December 29, 2015 - 9:19:41 AM


Files produced by the author(s)



Jaime Arias, Michell Guzmán, Carlos Olarte. A symbolic model for timed concurrent constraint programming. Ninth Workshop on Logical and Semantic Frameworks, with Applications (LSFA 2014), Sep 2014, Brasilia, Brazil. pp.161-177, ⟨10.1016/j.entcs.2015.04.010⟩. ⟨hal-01257078v2⟩



Record views


Files downloads