Efficient algorithms for program equivalence for confluent concurrent constraint programming

Luis F. Pino, Filippo Bonchi, Frank Valencia

Producción: Contribución a una revistaArtículorevisión exhaustiva

Resumen

Concurrent Constraint Programming (CCP) is a well-established declarative framework from concurrency theory. Its foundations and principles e.g., semantics, proof systems, axiomatizations, have been thoroughly studied for over the last two decades. In contrast, the development of algorithms and automatic verification procedures for CCP have hitherto been far too little considered. To the best of our knowledge there is only one existing verification algorithm for the standard notion of CCP program (observational) equivalence. In this paper we first show that this verification algorithm has an exponential-time complexity even for programs from a representative sub-language of CCP; the summation-free fragment (CCP\+). We then significantly improve on the complexity of this algorithm by providing two alternative polynomial-time decision procedures for CCP\+ program equivalence. Each of these two procedures has an advantage over the other. One has a better time complexity. The other can be easily adapted for the full language of CCP to produce significant state space reductions. The relevance of both procedures derives from the importance of CCP\+. This fragment, which has been the subject of many theoretical studies, has strong ties to first-order logic and an elegant denotational semantics, and it can be used to model real-world situations. Its most distinctive feature is that of confluence, a property we exploit to obtain our polynomial procedures. Finally, we also study the congruence issues regarding CCP's program equivalence.

Idioma originalInglés
Número de artículo1860
Páginas (desde-hasta)135-155
Número de páginas21
PublicaciónScience of Computer Programming
Volumen111
N.ºP1
DOI
EstadoPublicada - 01 nov. 2015
Publicado de forma externa

Huella

Profundice en los temas de investigación de 'Efficient algorithms for program equivalence for confluent concurrent constraint programming'. En conjunto forman una huella única.

Citar esto