Ciao Preprocessor (integrated Alpha version)
| This is an alpha distribution, meant only for testing. Please do let us
| know at ciaopp-bugclip.dia.fi.upm.es any problems you may have.
{loaded in 3404.213 msec.}
{preprocessed for plai in 0.0 msec.}
{analyzed by plai using det with local-control off in 12.001 msec.}
{written file /tmp/tmpowHTvw/inorder_det_co.pl}
:- module(_1,[inorder/2],[assertions]).
:- entry inorder(A,B)
: ground(A).
:- true pred inorder(A,B)
: ( native_props:mshare([[B]]), ground([A]), gnd(A), term(B) )
=> ( ground([A,B]), rt35(A), rt42(B) )
+ ( is_det, mut_exclusive ).
:- true pred inorder(A,B)
: ( native_props:mshare([[B]]), var(B), ground([A]), gnd(A), term(B) )
=> ( ground([A,B]), rt9(A), rt12(B) )
+ ( is_det, mut_exclusive ).
inorder(nil,[]).
inorder(tree(L,V,R),I) :-
inorder(L,LI),
inorder(R,RI),
append(LI,[V|RI],I).
:- true pred append(_1,[_2|_3],X)
: ( native_props:mshare([[X]]), ground([_1,_2,_3]), rt14(_1), term(X), gnd(_2), rt16(_3) )
=> ( ground([_1,X,_2,_3]), rt30(_1), rt18(X), gnd(_2), rt16(_3) )
+ ( is_det, mut_exclusive ).
:- true pred append(_1,Ys,X)
: ( native_props:mshare([[X]]), ground([_1,Ys]), rt15(_1), rt20(Ys), term(X) )
=> ( ground([_1,Ys,X]), rt25(_1), rt20(Ys), rt20(X) )
+ ( is_det, mut_exclusive ).
:- true pred append(_1,[_2|_3],X)
: ( native_props:mshare([[X]]), var(X), ground([_1,_2,_3]), rt3(_1), term(X), gnd(_2), rt3(_3) )
=> ( ground([_1,X,_2,_3]), rt5(_1), rt4(X), gnd(_2), rt3(_3) )
+ ( is_det, mut_exclusive ).
append([],X,X).
append([X|Xs],Ys,[X|Zs]) :-
append(Xs,Ys,Zs).
:- regtype rt41/1.
rt41(nil).
rt41(tree(A,B,C)) :-
rt41(A),
gnd(B),
rt40(C).
:- regtype rt40/1.
rt40(nil).
rt40(tree(A,B,C)) :-
rt41(A),
gnd(B),
rt40(C).
:- regtype rt39/1.
rt39(nil).
rt39(tree(A,B,C)) :-
rt41(A),
gnd(B),
rt40(C).
:- regtype rt38/1.
rt38(nil).
rt38(tree(A,B,C)) :-
rt38(A),
gnd(B),
rt37(C).
:- regtype rt37/1.
rt37(nil).
rt37(tree(A,B,C)) :-
rt38(A),
gnd(B),
rt37(C).
:- regtype rt36/1.
rt36(nil).
rt36(tree(A,B,C)) :-
rt38(A),
gnd(B),
rt37(C).
:- regtype rt35/1.
rt35(nil).
rt35(tree(A,B,C)) :-
rt39(A),
gnd(B),
rt36(C).
:- regtype rt43/1.
rt43([]).
rt43([A|B]) :-
gnd(A),
rt43(B).
:- regtype rt42/1.
rt42([]).
rt42([A|B]) :-
gnd(A),
rt43(B).
:- regtype rt14/1.
rt14([]).
rt14([A|B]) :-
gnd(A),
rt15(B).
:- regtype rt17/1.
rt17([]).
rt17([A|B]) :-
gnd(A),
rt17(B).
:- regtype rt16/1.
rt16([]).
rt16([A|B]) :-
gnd(A),
rt17(B).
:- regtype rt31/1.
rt31([]).
rt31([A|B]) :-
gnd(A),
rt31(B).
:- regtype rt30/1.
rt30([]).
rt30([A|B]) :-
gnd(A),
rt31(B).
:- regtype rt18/1.
rt18([A|B]) :-
gnd(A),
rt16(B).
:- regtype rt15/1.
rt15([]).
rt15([A|B]) :-
gnd(A),
rt15(B).
:- regtype rt20/1.
rt20([A|B]) :-
gnd(A),
rt16(B).
:- regtype rt26/1.
rt26([]).
rt26([A|B]) :-
gnd(A),
rt26(B).
:- regtype rt25/1.
rt25([]).
rt25([A|B]) :-
gnd(A),
rt26(B).
:- regtype rt11/1.
rt11(nil).
rt11(tree(A,B,C)) :-
rt11(A),
gnd(B),
rt10(C).
:- regtype rt10/1.
rt10(nil).
rt10(tree(A,B,C)) :-
rt11(A),
gnd(B),
rt10(C).
:- regtype rt9/1.
rt9(nil).
rt9(tree(A,B,C)) :-
rt11(A),
gnd(B),
rt10(C).
:- regtype rt13/1.
rt13([]).
rt13([A|B]) :-
gnd(A),
rt13(B).
:- regtype rt12/1.
rt12([]).
rt12([A|B]) :-
gnd(A),
rt13(B).
:- regtype rt3/1.
rt3([]).
:- regtype rt5/1.
rt5([]).
:- regtype rt4/1.
rt4([A|B]) :-
gnd(A),
rt3(B).