Suspension Analyses for Concurrent Logic Programs

30Citations
Citations of this article
12Readers
Mendeley users who have this article in their library.

Abstract

Concurrent logic languages specify reactive systems which consist of collections of communicating processes. The presence of unintended suspended computations is a common programming error which is difficult to detect using standard debugging and testing techniques. We develop a number of analyses, based on abstract interpretation, which succeed if a program is definitely suspension free. If an analysis fails, the program may, or may not, be suspension free. Examples demonstrate that the analyses are practically useful. They are conceptually simple and easy to justify because they are based directly on the transition system semantics of concurrent logic programs. A naive analysis must consider all scheduling policies. However, it is proven that for our analyses it suffices to consider only one scheduling policy, allowing for efficient implementation. © 1994, ACM. All rights reserved.

Cite

CITATION STYLE

APA

Codish, M., Falaschi, M., & Marriott, K. (1994). Suspension Analyses for Concurrent Logic Programs. ACM Transactions on Programming Languages and Systems (TOPLAS), 16(3), 649–686. https://doi.org/10.1145/177492.177656

Register to see more suggestions

Mendeley helps you to discover research relevant for your work.

Already have an account?

Save time finding and organizing research with Mendeley

Sign up for free