/export/starexec/sandbox2/solver/bin/starexec_run_FirstOrder /export/starexec/sandbox2/benchmark/theBenchmark.xml /export/starexec/sandbox2/output/output_files -------------------------------------------------------------------------------- MAYBE We consider the system theBenchmark. We are asked to determine termination of the following first-order TRS. 0 : [] --> o U11 : [o * o] --> o U21 : [o] --> o U31 : [o * o * o * o] --> o active : [o] --> o and : [o * o] --> o cons : [o * o] --> o isNat : [o] --> o isNatIList : [o] --> o isNatList : [o] --> o length : [o] --> o mark : [o] --> o nil : [] --> o s : [o] --> o take : [o * o] --> o tt : [] --> o zeros : [] --> o active(zeros) => mark(cons(0, zeros)) active(U11(tt, X)) => mark(s(length(X))) active(U21(tt)) => mark(nil) active(U31(tt, X, Y, Z)) => mark(cons(Z, take(Y, X))) active(and(tt, X)) => mark(X) active(isNat(0)) => mark(tt) active(isNat(length(X))) => mark(isNatList(X)) active(isNat(s(X))) => mark(isNat(X)) active(isNatIList(X)) => mark(isNatList(X)) active(isNatIList(zeros)) => mark(tt) active(isNatIList(cons(X, Y))) => mark(and(isNat(X), isNatIList(Y))) active(isNatList(nil)) => mark(tt) active(isNatList(cons(X, Y))) => mark(and(isNat(X), isNatList(Y))) active(isNatList(take(X, Y))) => mark(and(isNat(X), isNatIList(Y))) active(length(nil)) => mark(0) active(length(cons(X, Y))) => mark(U11(and(isNatList(Y), isNat(X)), Y)) active(take(0, X)) => mark(U21(isNatIList(X))) active(take(s(X), cons(Y, Z))) => mark(U31(and(isNatIList(Z), and(isNat(X), isNat(Y))), Z, X, Y)) mark(zeros) => active(zeros) mark(cons(X, Y)) => active(cons(mark(X), Y)) mark(0) => active(0) mark(U11(X, Y)) => active(U11(mark(X), Y)) mark(tt) => active(tt) mark(s(X)) => active(s(mark(X))) mark(length(X)) => active(length(mark(X))) mark(U21(X)) => active(U21(mark(X))) mark(nil) => active(nil) mark(U31(X, Y, Z, U)) => active(U31(mark(X), Y, Z, U)) mark(take(X, Y)) => active(take(mark(X), mark(Y))) mark(and(X, Y)) => active(and(mark(X), Y)) mark(isNat(X)) => active(isNat(X)) mark(isNatList(X)) => active(isNatList(X)) mark(isNatIList(X)) => active(isNatIList(X)) cons(mark(X), Y) => cons(X, Y) cons(X, mark(Y)) => cons(X, Y) cons(active(X), Y) => cons(X, Y) cons(X, active(Y)) => cons(X, Y) U11(mark(X), Y) => U11(X, Y) U11(X, mark(Y)) => U11(X, Y) U11(active(X), Y) => U11(X, Y) U11(X, active(Y)) => U11(X, Y) s(mark(X)) => s(X) s(active(X)) => s(X) length(mark(X)) => length(X) length(active(X)) => length(X) U21(mark(X)) => U21(X) U21(active(X)) => U21(X) U31(mark(X), Y, Z, U) => U31(X, Y, Z, U) U31(X, mark(Y), Z, U) => U31(X, Y, Z, U) U31(X, Y, mark(Z), U) => U31(X, Y, Z, U) U31(X, Y, Z, mark(U)) => U31(X, Y, Z, U) U31(active(X), Y, Z, U) => U31(X, Y, Z, U) U31(X, active(Y), Z, U) => U31(X, Y, Z, U) U31(X, Y, active(Z), U) => U31(X, Y, Z, U) U31(X, Y, Z, active(U)) => U31(X, Y, Z, U) take(mark(X), Y) => take(X, Y) take(X, mark(Y)) => take(X, Y) take(active(X), Y) => take(X, Y) take(X, active(Y)) => take(X, Y) and(mark(X), Y) => and(X, Y) and(X, mark(Y)) => and(X, Y) and(active(X), Y) => and(X, Y) and(X, active(Y)) => and(X, Y) isNat(mark(X)) => isNat(X) isNat(active(X)) => isNat(X) isNatList(mark(X)) => isNatList(X) isNatList(active(X)) => isNatList(X) isNatIList(mark(X)) => isNatIList(X) isNatIList(active(X)) => isNatIList(X)