The rewrite relation of the following TRS is considered.
active(U11(tt,N)) | → | mark(N) | (1) |
active(U21(tt,M,N)) | → | mark(s(plus(N,M))) | (2) |
active(U31(tt)) | → | mark(0) | (3) |
active(U41(tt,M,N)) | → | mark(plus(x(N,M),N)) | (4) |
active(and(tt,X)) | → | mark(X) | (5) |
active(isNat(0)) | → | mark(tt) | (6) |
active(isNat(plus(V1,V2))) | → | mark(and(isNat(V1),isNat(V2))) | (7) |
active(isNat(s(V1))) | → | mark(isNat(V1)) | (8) |
active(isNat(x(V1,V2))) | → | mark(and(isNat(V1),isNat(V2))) | (9) |
active(plus(N,0)) | → | mark(U11(isNat(N),N)) | (10) |
active(plus(N,s(M))) | → | mark(U21(and(isNat(M),isNat(N)),M,N)) | (11) |
active(x(N,0)) | → | mark(U31(isNat(N))) | (12) |
active(x(N,s(M))) | → | mark(U41(and(isNat(M),isNat(N)),M,N)) | (13) |
active(U11(X1,X2)) | → | U11(active(X1),X2) | (14) |
active(U21(X1,X2,X3)) | → | U21(active(X1),X2,X3) | (15) |
active(s(X)) | → | s(active(X)) | (16) |
active(plus(X1,X2)) | → | plus(active(X1),X2) | (17) |
active(plus(X1,X2)) | → | plus(X1,active(X2)) | (18) |
active(U31(X)) | → | U31(active(X)) | (19) |
active(U41(X1,X2,X3)) | → | U41(active(X1),X2,X3) | (20) |
active(x(X1,X2)) | → | x(active(X1),X2) | (21) |
active(x(X1,X2)) | → | x(X1,active(X2)) | (22) |
active(and(X1,X2)) | → | and(active(X1),X2) | (23) |
U11(mark(X1),X2) | → | mark(U11(X1,X2)) | (24) |
U21(mark(X1),X2,X3) | → | mark(U21(X1,X2,X3)) | (25) |
s(mark(X)) | → | mark(s(X)) | (26) |
plus(mark(X1),X2) | → | mark(plus(X1,X2)) | (27) |
plus(X1,mark(X2)) | → | mark(plus(X1,X2)) | (28) |
U31(mark(X)) | → | mark(U31(X)) | (29) |
U41(mark(X1),X2,X3) | → | mark(U41(X1,X2,X3)) | (30) |
x(mark(X1),X2) | → | mark(x(X1,X2)) | (31) |
x(X1,mark(X2)) | → | mark(x(X1,X2)) | (32) |
and(mark(X1),X2) | → | mark(and(X1,X2)) | (33) |
proper(U11(X1,X2)) | → | U11(proper(X1),proper(X2)) | (34) |
proper(tt) | → | ok(tt) | (35) |
proper(U21(X1,X2,X3)) | → | U21(proper(X1),proper(X2),proper(X3)) | (36) |
proper(s(X)) | → | s(proper(X)) | (37) |
proper(plus(X1,X2)) | → | plus(proper(X1),proper(X2)) | (38) |
proper(U31(X)) | → | U31(proper(X)) | (39) |
proper(0) | → | ok(0) | (40) |
proper(U41(X1,X2,X3)) | → | U41(proper(X1),proper(X2),proper(X3)) | (41) |
proper(x(X1,X2)) | → | x(proper(X1),proper(X2)) | (42) |
proper(and(X1,X2)) | → | and(proper(X1),proper(X2)) | (43) |
proper(isNat(X)) | → | isNat(proper(X)) | (44) |
U11(ok(X1),ok(X2)) | → | ok(U11(X1,X2)) | (45) |
U21(ok(X1),ok(X2),ok(X3)) | → | ok(U21(X1,X2,X3)) | (46) |
s(ok(X)) | → | ok(s(X)) | (47) |
plus(ok(X1),ok(X2)) | → | ok(plus(X1,X2)) | (48) |
U31(ok(X)) | → | ok(U31(X)) | (49) |
U41(ok(X1),ok(X2),ok(X3)) | → | ok(U41(X1,X2,X3)) | (50) |
x(ok(X1),ok(X2)) | → | ok(x(X1,X2)) | (51) |
and(ok(X1),ok(X2)) | → | ok(and(X1,X2)) | (52) |
isNat(ok(X)) | → | ok(isNat(X)) | (53) |
top(mark(X)) | → | top(proper(X)) | (54) |
top(ok(X)) | → | top(active(X)) | (55) |
prec(U11) | = | 2 | stat(U11) | = | mul | |
prec(tt) | = | 1 | stat(tt) | = | mul | |
prec(U21) | = | 4 | stat(U21) | = | lex | |
prec(s) | = | 1 | stat(s) | = | mul | |
prec(plus) | = | 4 | stat(plus) | = | lex | |
prec(U31) | = | 5 | stat(U31) | = | mul | |
prec(0) | = | 2 | stat(0) | = | mul | |
prec(U41) | = | 6 | stat(U41) | = | lex | |
prec(x) | = | 6 | stat(x) | = | lex | |
prec(and) | = | 3 | stat(and) | = | mul | |
prec(top) | = | 0 | stat(top) | = | mul |
π(active) | = | 1 |
π(U11) | = | [1,2] |
π(tt) | = | [] |
π(mark) | = | 1 |
π(U21) | = | [3,2,1] |
π(s) | = | [1] |
π(plus) | = | [1,2] |
π(U31) | = | [1] |
π(0) | = | [] |
π(U41) | = | [3,2,1] |
π(x) | = | [1,2] |
π(and) | = | [1,2] |
π(isNat) | = | 1 |
π(proper) | = | 1 |
π(ok) | = | 1 |
π(top) | = | [1] |
active(U11(tt,N)) | → | mark(N) | (1) |
active(U21(tt,M,N)) | → | mark(s(plus(N,M))) | (2) |
active(U31(tt)) | → | mark(0) | (3) |
active(U41(tt,M,N)) | → | mark(plus(x(N,M),N)) | (4) |
active(and(tt,X)) | → | mark(X) | (5) |
active(isNat(0)) | → | mark(tt) | (6) |
active(isNat(plus(V1,V2))) | → | mark(and(isNat(V1),isNat(V2))) | (7) |
active(isNat(s(V1))) | → | mark(isNat(V1)) | (8) |
active(isNat(x(V1,V2))) | → | mark(and(isNat(V1),isNat(V2))) | (9) |
active(plus(N,0)) | → | mark(U11(isNat(N),N)) | (10) |
active(plus(N,s(M))) | → | mark(U21(and(isNat(M),isNat(N)),M,N)) | (11) |
active(x(N,0)) | → | mark(U31(isNat(N))) | (12) |
active(x(N,s(M))) | → | mark(U41(and(isNat(M),isNat(N)),M,N)) | (13) |
[active(x1)] | = | 2 · x1 |
[U11(x1, x2)] | = | 2 · x1 + 1 · x2 |
[U21(x1, x2, x3)] | = | 2 · x1 + 2 · x2 + 1 · x3 |
[s(x1)] | = | 2 · x1 |
[plus(x1, x2)] | = | 2 · x1 + 2 · x2 |
[U31(x1)] | = | 2 · x1 |
[U41(x1, x2, x3)] | = | 2 · x1 + 2 · x2 + 2 · x3 |
[x(x1, x2)] | = | 2 · x1 + 2 · x2 |
[and(x1, x2)] | = | 2 · x1 + 2 · x2 |
[mark(x1)] | = | 2 + 1 · x1 |
[proper(x1)] | = | 1 · x1 |
[tt] | = | 0 |
[ok(x1)] | = | 2 · x1 |
[0] | = | 0 |
[isNat(x1)] | = | 2 · x1 |
[top(x1)] | = | 1 · x1 |
U11(mark(X1),X2) | → | mark(U11(X1,X2)) | (24) |
U21(mark(X1),X2,X3) | → | mark(U21(X1,X2,X3)) | (25) |
s(mark(X)) | → | mark(s(X)) | (26) |
plus(mark(X1),X2) | → | mark(plus(X1,X2)) | (27) |
plus(X1,mark(X2)) | → | mark(plus(X1,X2)) | (28) |
U31(mark(X)) | → | mark(U31(X)) | (29) |
U41(mark(X1),X2,X3) | → | mark(U41(X1,X2,X3)) | (30) |
x(mark(X1),X2) | → | mark(x(X1,X2)) | (31) |
x(X1,mark(X2)) | → | mark(x(X1,X2)) | (32) |
and(mark(X1),X2) | → | mark(and(X1,X2)) | (33) |
top(mark(X)) | → | top(proper(X)) | (54) |
[active(x1)] | = | 2 · x1 |
[U11(x1, x2)] | = | 2 + 2 · x1 + 1 · x2 |
[U21(x1, x2, x3)] | = | 2 + 1 · x1 + 1 · x2 + 1 · x3 |
[s(x1)] | = | 1 · x1 |
[plus(x1, x2)] | = | 1 + 1 · x1 + 1 · x2 |
[U31(x1)] | = | 1 · x1 |
[U41(x1, x2, x3)] | = | 2 + 1 · x1 + 1 · x2 + 1 · x3 |
[x(x1, x2)] | = | 1 + 1 · x1 + 1 · x2 |
[and(x1, x2)] | = | 1 + 1 · x1 + 1 · x2 |
[proper(x1)] | = | 1 + 2 · x1 |
[tt] | = | 0 |
[ok(x1)] | = | 1 + 2 · x1 |
[0] | = | 0 |
[isNat(x1)] | = | 1 · x1 |
[top(x1)] | = | 1 · x1 |
active(U11(X1,X2)) | → | U11(active(X1),X2) | (14) |
active(U21(X1,X2,X3)) | → | U21(active(X1),X2,X3) | (15) |
active(plus(X1,X2)) | → | plus(active(X1),X2) | (17) |
active(plus(X1,X2)) | → | plus(X1,active(X2)) | (18) |
active(U41(X1,X2,X3)) | → | U41(active(X1),X2,X3) | (20) |
active(x(X1,X2)) | → | x(active(X1),X2) | (21) |
active(x(X1,X2)) | → | x(X1,active(X2)) | (22) |
active(and(X1,X2)) | → | and(active(X1),X2) | (23) |
top(ok(X)) | → | top(active(X)) | (55) |
[active(x1)] | = | 2 · x1 |
[s(x1)] | = | 2 + 2 · x1 |
[U31(x1)] | = | 2 · x1 |
[proper(x1)] | = | 2 · x1 |
[U11(x1, x2)] | = | 2 · x1 + 2 · x2 |
[tt] | = | 1 |
[ok(x1)] | = | 1 + 1 · x1 |
[U21(x1, x2, x3)] | = | 2 + 2 · x1 + 2 · x2 + 2 · x3 |
[plus(x1, x2)] | = | 1 + 2 · x1 + 2 · x2 |
[0] | = | 1 |
[U41(x1, x2, x3)] | = | 1 · x1 + 1 · x2 + 1 · x3 |
[x(x1, x2)] | = | 2 · x1 + 2 · x2 |
[and(x1, x2)] | = | 2 · x1 + 2 · x2 |
[isNat(x1)] | = | 2 + 2 · x1 |
active(s(X)) | → | s(active(X)) | (16) |
proper(U21(X1,X2,X3)) | → | U21(proper(X1),proper(X2),proper(X3)) | (36) |
proper(s(X)) | → | s(proper(X)) | (37) |
proper(plus(X1,X2)) | → | plus(proper(X1),proper(X2)) | (38) |
proper(isNat(X)) | → | isNat(proper(X)) | (44) |
U11(ok(X1),ok(X2)) | → | ok(U11(X1,X2)) | (45) |
U21(ok(X1),ok(X2),ok(X3)) | → | ok(U21(X1,X2,X3)) | (46) |
s(ok(X)) | → | ok(s(X)) | (47) |
plus(ok(X1),ok(X2)) | → | ok(plus(X1,X2)) | (48) |
U31(ok(X)) | → | ok(U31(X)) | (49) |
U41(ok(X1),ok(X2),ok(X3)) | → | ok(U41(X1,X2,X3)) | (50) |
x(ok(X1),ok(X2)) | → | ok(x(X1,X2)) | (51) |
and(ok(X1),ok(X2)) | → | ok(and(X1,X2)) | (52) |
isNat(ok(X)) | → | ok(isNat(X)) | (53) |
[active(x1)] | = | 2 · x1 |
[U31(x1)] | = | 1 + 2 · x1 |
[proper(x1)] | = | 2 · x1 |
[U11(x1, x2)] | = | 1 + 1 · x1 + 1 · x2 |
[tt] | = | 1 |
[ok(x1)] | = | 1 · x1 |
[0] | = | 1 |
[U41(x1, x2, x3)] | = | 1 + 2 · x1 + 1 · x2 + 1 · x3 |
[x(x1, x2)] | = | 1 · x1 + 1 · x2 |
[and(x1, x2)] | = | 1 + 2 · x1 + 2 · x2 |
active(U31(X)) | → | U31(active(X)) | (19) |
proper(U11(X1,X2)) | → | U11(proper(X1),proper(X2)) | (34) |
proper(tt) | → | ok(tt) | (35) |
proper(U31(X)) | → | U31(proper(X)) | (39) |
proper(0) | → | ok(0) | (40) |
proper(U41(X1,X2,X3)) | → | U41(proper(X1),proper(X2),proper(X3)) | (41) |
proper(and(X1,X2)) | → | and(proper(X1),proper(X2)) | (43) |
prec(proper) | = | 1 | weight(proper) | = | 0 | ||||
prec(x) | = | 0 | weight(x) | = | 0 |
proper(x(X1,X2)) | → | x(proper(X1),proper(X2)) | (42) |
There are no rules in the TRS. Hence, it is terminating.