Files
mercury/tests/tabling/coup3.m
2018-07-08 23:20:52 +02:00

79 lines
1.6 KiB
Mathematica

%---------------------------------------------------------------------------%
% vim: ts=4 sw=4 et ft=mercury
%---------------------------------------------------------------------------%
%
% This is a test for whether multiple coups (change of leaders)
% are correctly handled.
:- module coup3.
:- interface.
:- import_module io.
:- pred main(io::di, io::uo) is det.
:- implementation.
:- import_module int.
:- import_module list.
:- import_module solutions.
:- pragma require_feature_set([memo]).
main(!IO) :-
solutions(p, SolnsP),
io.write_string("P = ", !IO),
io.write(SolnsP, !IO),
io.write_string("\n", !IO),
solutions(q, SolnsQ),
io.write_string("Q = ", !IO),
io.write(SolnsQ, !IO),
io.write_string("\n", !IO),
solutions(r, SolnsR),
io.write_string("R = ", !IO),
io.write(SolnsR, !IO),
io.write_string("\n", !IO).
:- pred p(int::out) is nondet.
:- pragma minimal_model(p/1).
p(X) :-
(
p(Y),
X = 2 * Y,
X < 20
;
q(X)
).
:- pred q(int::out) is nondet.
:- pragma minimal_model(q/1).
q(X) :-
(
X = 1
;
q(Y), % suspend execution -- q is its own leader here
X = 3 * Y,
X < 20
;
r(X)
).
:- pred r(int::out) is nondet.
:- pragma minimal_model(r/1).
r(X) :-
(
X = 1 % r is its own leader at this point
;
q(Y), % here a coup takes place -- leader becomes q
X = 4 * Y,
X < 20
;
p(Y), % another coup takes place -- leader becomes p
X = 5 * Y,
X < 20
).