MAYBE 268.01/67.83 MAYBE 268.01/67.83 268.01/67.83 Problem: 268.01/67.83 active(__(__(X,Y),Z)) -> mark(__(X,__(Y,Z))) 268.01/67.83 active(__(X,nil())) -> mark(X) 268.01/67.83 active(__(nil(),X)) -> mark(X) 268.01/67.83 active(and(tt(),X)) -> mark(X) 268.01/67.83 active(isList(V)) -> mark(isNeList(V)) 268.01/67.83 active(isList(nil())) -> mark(tt()) 268.01/67.83 active(isList(__(V1,V2))) -> mark(and(isList(V1),isList(V2))) 268.01/67.83 active(isNeList(V)) -> mark(isQid(V)) 268.01/67.83 active(isNeList(__(V1,V2))) -> mark(and(isList(V1),isNeList(V2))) 268.01/67.83 active(isNeList(__(V1,V2))) -> mark(and(isNeList(V1),isList(V2))) 268.01/67.83 active(isNePal(V)) -> mark(isQid(V)) 268.01/67.83 active(isNePal(__(I,__(P,I)))) -> mark(and(isQid(I),isPal(P))) 268.01/67.83 active(isPal(V)) -> mark(isNePal(V)) 268.01/67.83 active(isPal(nil())) -> mark(tt()) 268.01/67.83 active(isQid(a())) -> mark(tt()) 268.01/67.83 active(isQid(e())) -> mark(tt()) 268.01/67.83 active(isQid(i())) -> mark(tt()) 268.01/67.83 active(isQid(o())) -> mark(tt()) 268.01/67.83 active(isQid(u())) -> mark(tt()) 268.01/67.83 active(__(X1,X2)) -> __(active(X1),X2) 268.01/67.83 active(__(X1,X2)) -> __(X1,active(X2)) 268.01/67.83 active(and(X1,X2)) -> and(active(X1),X2) 268.01/67.83 __(mark(X1),X2) -> mark(__(X1,X2)) 268.01/67.83 __(X1,mark(X2)) -> mark(__(X1,X2)) 268.01/67.83 and(mark(X1),X2) -> mark(and(X1,X2)) 268.01/67.83 proper(__(X1,X2)) -> __(proper(X1),proper(X2)) 268.01/67.83 proper(nil()) -> ok(nil()) 268.01/67.83 proper(and(X1,X2)) -> and(proper(X1),proper(X2)) 268.01/67.83 proper(tt()) -> ok(tt()) 268.01/67.83 proper(isList(X)) -> isList(proper(X)) 268.01/67.83 proper(isNeList(X)) -> isNeList(proper(X)) 268.01/67.83 proper(isQid(X)) -> isQid(proper(X)) 268.01/67.83 proper(isNePal(X)) -> isNePal(proper(X)) 268.01/67.83 proper(isPal(X)) -> isPal(proper(X)) 268.01/67.83 proper(a()) -> ok(a()) 268.01/67.83 proper(e()) -> ok(e()) 268.01/67.83 proper(i()) -> ok(i()) 268.01/67.83 proper(o()) -> ok(o()) 268.01/67.83 proper(u()) -> ok(u()) 268.01/67.83 __(ok(X1),ok(X2)) -> ok(__(X1,X2)) 268.01/67.83 and(ok(X1),ok(X2)) -> ok(and(X1,X2)) 268.01/67.83 isList(ok(X)) -> ok(isList(X)) 268.01/67.83 isNeList(ok(X)) -> ok(isNeList(X)) 268.01/67.83 isQid(ok(X)) -> ok(isQid(X)) 268.01/67.83 isNePal(ok(X)) -> ok(isNePal(X)) 268.01/67.83 isPal(ok(X)) -> ok(isPal(X)) 268.01/67.83 top(mark(X)) -> top(proper(X)) 268.01/67.83 top(ok(X)) -> top(active(X)) 268.01/67.83 268.01/67.83 Proof: 268.01/67.83 Open 268.01/67.83 EOF