YES
0 QTRS
↳1 QTRSRRRProof (⇔, 73 ms)
↳2 QTRS
↳3 QTRSRRRProof (⇔, 0 ms)
↳4 QTRS
↳5 QTRSRRRProof (⇔, 0 ms)
↳6 QTRS
↳7 QTRSRRRProof (⇔, 0 ms)
↳8 QTRS
↳9 QTRSRRRProof (⇔, 0 ms)
↳10 QTRS
↳11 QTRSRRRProof (⇔, 0 ms)
↳12 QTRS
↳13 QTRSRRRProof (⇔, 0 ms)
↳14 QTRS
↳15 QTRSRRRProof (⇔, 0 ms)
↳16 QTRS
↳17 RisEmptyProof (⇔, 0 ms)
↳18 YES
a__nats → a__adx(a__zeros)
a__zeros → cons(0, zeros)
a__incr(cons(X, Y)) → cons(s(X), incr(Y))
a__adx(cons(X, Y)) → a__incr(cons(X, adx(Y)))
a__hd(cons(X, Y)) → mark(X)
a__tl(cons(X, Y)) → mark(Y)
mark(nats) → a__nats
mark(adx(X)) → a__adx(mark(X))
mark(zeros) → a__zeros
mark(incr(X)) → a__incr(mark(X))
mark(hd(X)) → a__hd(mark(X))
mark(tl(X)) → a__tl(mark(X))
mark(cons(X1, X2)) → cons(X1, X2)
mark(0) → 0
mark(s(X)) → s(X)
a__nats → nats
a__adx(X) → adx(X)
a__zeros → zeros
a__incr(X) → incr(X)
a__hd(X) → hd(X)
a__tl(X) → tl(X)
With this ordering the following rules can be removed by the rule removal processor [LPAR04] because they are oriented strictly:
POL(0) = 0
POL(a__adx(x1)) = 2·x1
POL(a__hd(x1)) = 2 + 2·x1
POL(a__incr(x1)) = x1
POL(a__nats) = 0
POL(a__tl(x1)) = x1
POL(a__zeros) = 0
POL(adx(x1)) = 2·x1
POL(cons(x1, x2)) = 2·x1 + 2·x2
POL(hd(x1)) = 2 + 2·x1
POL(incr(x1)) = x1
POL(mark(x1)) = x1
POL(nats) = 0
POL(s(x1)) = x1
POL(tl(x1)) = x1
POL(zeros) = 0
a__hd(cons(X, Y)) → mark(X)
a__nats → a__adx(a__zeros)
a__zeros → cons(0, zeros)
a__incr(cons(X, Y)) → cons(s(X), incr(Y))
a__adx(cons(X, Y)) → a__incr(cons(X, adx(Y)))
a__tl(cons(X, Y)) → mark(Y)
mark(nats) → a__nats
mark(adx(X)) → a__adx(mark(X))
mark(zeros) → a__zeros
mark(incr(X)) → a__incr(mark(X))
mark(hd(X)) → a__hd(mark(X))
mark(tl(X)) → a__tl(mark(X))
mark(cons(X1, X2)) → cons(X1, X2)
mark(0) → 0
mark(s(X)) → s(X)
a__nats → nats
a__adx(X) → adx(X)
a__zeros → zeros
a__incr(X) → incr(X)
a__hd(X) → hd(X)
a__tl(X) → tl(X)
With this ordering the following rules can be removed by the rule removal processor [LPAR04] because they are oriented strictly:
POL(0) = 0
POL(a__adx(x1)) = x1
POL(a__hd(x1)) = 2 + x1
POL(a__incr(x1)) = x1
POL(a__nats) = 2
POL(a__tl(x1)) = 2 + 2·x1
POL(a__zeros) = 0
POL(adx(x1)) = x1
POL(cons(x1, x2)) = x1 + 2·x2
POL(hd(x1)) = 2 + x1
POL(incr(x1)) = x1
POL(mark(x1)) = 2·x1
POL(nats) = 1
POL(s(x1)) = x1
POL(tl(x1)) = 1 + 2·x1
POL(zeros) = 0
a__nats → a__adx(a__zeros)
a__tl(cons(X, Y)) → mark(Y)
mark(hd(X)) → a__hd(mark(X))
a__nats → nats
a__tl(X) → tl(X)
a__zeros → cons(0, zeros)
a__incr(cons(X, Y)) → cons(s(X), incr(Y))
a__adx(cons(X, Y)) → a__incr(cons(X, adx(Y)))
mark(nats) → a__nats
mark(adx(X)) → a__adx(mark(X))
mark(zeros) → a__zeros
mark(incr(X)) → a__incr(mark(X))
mark(tl(X)) → a__tl(mark(X))
mark(cons(X1, X2)) → cons(X1, X2)
mark(0) → 0
mark(s(X)) → s(X)
a__adx(X) → adx(X)
a__zeros → zeros
a__incr(X) → incr(X)
a__hd(X) → hd(X)
With this ordering the following rules can be removed by the rule removal processor [LPAR04] because they are oriented strictly:
POL(0) = 0
POL(a__adx(x1)) = x1
POL(a__hd(x1)) = 2 + 2·x1
POL(a__incr(x1)) = x1
POL(a__nats) = 0
POL(a__tl(x1)) = x1
POL(a__zeros) = 0
POL(adx(x1)) = x1
POL(cons(x1, x2)) = 2·x1 + x2
POL(hd(x1)) = 1 + x1
POL(incr(x1)) = x1
POL(mark(x1)) = x1
POL(nats) = 0
POL(s(x1)) = x1
POL(tl(x1)) = 2·x1
POL(zeros) = 0
a__hd(X) → hd(X)
a__zeros → cons(0, zeros)
a__incr(cons(X, Y)) → cons(s(X), incr(Y))
a__adx(cons(X, Y)) → a__incr(cons(X, adx(Y)))
mark(nats) → a__nats
mark(adx(X)) → a__adx(mark(X))
mark(zeros) → a__zeros
mark(incr(X)) → a__incr(mark(X))
mark(tl(X)) → a__tl(mark(X))
mark(cons(X1, X2)) → cons(X1, X2)
mark(0) → 0
mark(s(X)) → s(X)
a__adx(X) → adx(X)
a__zeros → zeros
a__incr(X) → incr(X)
With this ordering the following rules can be removed by the rule removal processor [LPAR04] because they are oriented strictly:
POL(0) = 1
POL(a__adx(x1)) = x1
POL(a__incr(x1)) = x1
POL(a__nats) = 1
POL(a__tl(x1)) = 1 + 2·x1
POL(a__zeros) = 2
POL(adx(x1)) = x1
POL(cons(x1, x2)) = 2·x1 + 2·x2
POL(incr(x1)) = x1
POL(mark(x1)) = 2 + 2·x1
POL(nats) = 0
POL(s(x1)) = x1
POL(tl(x1)) = 2 + 2·x1
POL(zeros) = 0
mark(nats) → a__nats
mark(tl(X)) → a__tl(mark(X))
mark(cons(X1, X2)) → cons(X1, X2)
mark(0) → 0
mark(s(X)) → s(X)
a__zeros → zeros
a__zeros → cons(0, zeros)
a__incr(cons(X, Y)) → cons(s(X), incr(Y))
a__adx(cons(X, Y)) → a__incr(cons(X, adx(Y)))
mark(adx(X)) → a__adx(mark(X))
mark(zeros) → a__zeros
mark(incr(X)) → a__incr(mark(X))
a__adx(X) → adx(X)
a__incr(X) → incr(X)
With this ordering the following rules can be removed by the rule removal processor [LPAR04] because they are oriented strictly:
POL(0) = 0
POL(a__adx(x1)) = 2 + 2·x1
POL(a__incr(x1)) = 2 + x1
POL(a__zeros) = 2
POL(adx(x1)) = 2 + 2·x1
POL(cons(x1, x2)) = 2 + 2·x1 + x2
POL(incr(x1)) = 1 + x1
POL(mark(x1)) = 2 + 2·x1
POL(s(x1)) = x1
POL(zeros) = 0
a__incr(cons(X, Y)) → cons(s(X), incr(Y))
a__incr(X) → incr(X)
a__zeros → cons(0, zeros)
a__adx(cons(X, Y)) → a__incr(cons(X, adx(Y)))
mark(adx(X)) → a__adx(mark(X))
mark(zeros) → a__zeros
mark(incr(X)) → a__incr(mark(X))
a__adx(X) → adx(X)
With this ordering the following rules can be removed by the rule removal processor [LPAR04] because they are oriented strictly:
POL(0) = 0
POL(a__adx(x1)) = 2 + x1
POL(a__incr(x1)) = 1 + x1
POL(a__zeros) = 2
POL(adx(x1)) = 1 + x1
POL(cons(x1, x2)) = 1 + 2·x1 + x2
POL(incr(x1)) = 2 + 2·x1
POL(mark(x1)) = 1 + 2·x1
POL(zeros) = 1
mark(zeros) → a__zeros
mark(incr(X)) → a__incr(mark(X))
a__adx(X) → adx(X)
a__zeros → cons(0, zeros)
a__adx(cons(X, Y)) → a__incr(cons(X, adx(Y)))
mark(adx(X)) → a__adx(mark(X))
With this ordering the following rules can be removed by the rule removal processor [LPAR04] because they are oriented strictly:
POL(0) = 0
POL(a__adx(x1)) = 2·x1
POL(a__incr(x1)) = x1
POL(a__zeros) = 2
POL(adx(x1)) = 2 + 2·x1
POL(cons(x1, x2)) = 2 + 2·x1 + x2
POL(mark(x1)) = 1 + 2·x1
POL(zeros) = 0
mark(adx(X)) → a__adx(mark(X))
a__zeros → cons(0, zeros)
a__adx(cons(X, Y)) → a__incr(cons(X, adx(Y)))
adx1 > aadx1 > aincr1 > zeros > 0 > azeros > cons2
a__zeros=2
0=1
zeros=1
a__adx_1=2
a__incr_1=1
adx_1=1
cons_2=0
a__zeros → cons(0, zeros)
a__adx(cons(X, Y)) → a__incr(cons(X, adx(Y)))