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

82 lines
1.7 KiB
Mathematica

%---------------------------------------------------------------------------%
% vim: ts=4 sw=4 et ft=mercury
%---------------------------------------------------------------------------%
%
% This is a test for whether a single coup that takes leadership away from
% multiple generators is correctly handled.
%
% The code in this file is the same as coup3, except the order of clauses in r.
:- module coup4.
:- 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
;
p(Y), % here a coup takes place -- p becomes leader
% of both q and r
X = 5 * Y,
X < 20
;
q(Y),
X = 4 * Y,
X < 20
).