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).