In this paper we introduce a methodology for utilizing concurrency in place of backtracking in the implementation of nondeterministic algorithms. This is achieved in an applicative setting through the use of the Friedman-Wise multiprogramming primitive frons, and a paradigm which views the action of nondeterministic algorithms as one of data structure construction. The element by element nondeterminism arising from a linearized search is replaced by a control structure which is oriented towards constructing sets of partial computations. This point of view is facilitated by the use of suspensions, which allow control disciplines to be embodied in the form of conceptual data structures that in reality manifest themselves only for purposes of control. We apply this methodology to the class of problems usually solved through the use of simple backtracking (e.g. ''eight queens''), and to a problem presented by Lindstrom to illustrate the use of coroutine controlled backtracking, to produce backtrack-free solutions. Our solution to the latter illustrates the coroutine capability of suspended structures, but also demonstrates a need for further investigations into resolving problems of process communication in applicative languages.
[1]
Franco Turini,et al.
Two-level control structure for nondeterministic programming
,
1977,
CACM.
[2]
Gary Lindstrom,et al.
Backtracking in a Generalized Control Setting
,
1979,
TOPL.
[3]
Edward M. Reingold,et al.
Backtrack programming techniques
,
1975,
CACM.
[4]
Jacques Cohen,et al.
Non-Deterministic Algorithms
,
1979,
CSUR.
[5]
Gerald Jay Sussman,et al.
The Revised Report on SCHEME: A Dialect of LISP.
,
1978
.
[6]
Edsger W. Dijkstra,et al.
Notes on structured programming
,
1970
.
[7]
Daniel P. Friedman,et al.
An Approach to Fair Applicative Multiprogramming
,
1979,
Semantics of Concurrent Computation.
[8]
Robert W. Floyd,et al.
Nondeterministic Algorithms
,
1967,
JACM.
[9]
Daniel P. Friedman,et al.
An indeterminate constructor for applicative programming
,
1980,
POPL '80.
[10]
John McCarthy,et al.
A BASIS FOR A MATHEMATICAL THEORY OF COMPUTATION 1)
,
2018
.
[11]
Daniel P. Friedman,et al.
Unbounded computational structures
,
1978,
Softw. Pract. Exp..