0 QTRS
↳1 QTRSToCSRProof (⇔)
↳2 CSR
↳3 CSDependencyPairsProof (⇔)
↳4 QCSDP
↳5 QCSDependencyGraphProof (⇔)
↳6 AND
↳7 QCSDP
↳8 QCSDPSubtermProof (⇔)
↳9 QCSDP
↳10 PIsEmptyProof (⇔)
↳11 TRUE
↳12 QCSDP
↳13 QCSDPReductionPairProof (⇔)
↳14 QCSDP
↳15 PIsEmptyProof (⇔)
↳16 TRUE
↳17 QCSDP
↳18 QCSDPSubtermProof (⇔)
↳19 QCSDP
↳20 PIsEmptyProof (⇔)
↳21 TRUE
↳22 QCSDP
↳23 QCSDPSubtermProof (⇔)
↳24 QCSDP
↳25 PIsEmptyProof (⇔)
↳26 TRUE
active(from(X)) → mark(cons(X, from(s(X))))
active(sel(0, cons(X, XS))) → mark(X)
active(sel(s(N), cons(X, XS))) → mark(sel(N, XS))
active(minus(X, 0)) → mark(0)
active(minus(s(X), s(Y))) → mark(minus(X, Y))
active(quot(0, s(Y))) → mark(0)
active(quot(s(X), s(Y))) → mark(s(quot(minus(X, Y), s(Y))))
active(zWquot(XS, nil)) → mark(nil)
active(zWquot(nil, XS)) → mark(nil)
active(zWquot(cons(X, XS), cons(Y, YS))) → mark(cons(quot(X, Y), zWquot(XS, YS)))
active(from(X)) → from(active(X))
active(cons(X1, X2)) → cons(active(X1), X2)
active(s(X)) → s(active(X))
active(sel(X1, X2)) → sel(active(X1), X2)
active(sel(X1, X2)) → sel(X1, active(X2))
active(minus(X1, X2)) → minus(active(X1), X2)
active(minus(X1, X2)) → minus(X1, active(X2))
active(quot(X1, X2)) → quot(active(X1), X2)
active(quot(X1, X2)) → quot(X1, active(X2))
active(zWquot(X1, X2)) → zWquot(active(X1), X2)
active(zWquot(X1, X2)) → zWquot(X1, active(X2))
from(mark(X)) → mark(from(X))
cons(mark(X1), X2) → mark(cons(X1, X2))
s(mark(X)) → mark(s(X))
sel(mark(X1), X2) → mark(sel(X1, X2))
sel(X1, mark(X2)) → mark(sel(X1, X2))
minus(mark(X1), X2) → mark(minus(X1, X2))
minus(X1, mark(X2)) → mark(minus(X1, X2))
quot(mark(X1), X2) → mark(quot(X1, X2))
quot(X1, mark(X2)) → mark(quot(X1, X2))
zWquot(mark(X1), X2) → mark(zWquot(X1, X2))
zWquot(X1, mark(X2)) → mark(zWquot(X1, X2))
proper(from(X)) → from(proper(X))
proper(cons(X1, X2)) → cons(proper(X1), proper(X2))
proper(s(X)) → s(proper(X))
proper(sel(X1, X2)) → sel(proper(X1), proper(X2))
proper(0) → ok(0)
proper(minus(X1, X2)) → minus(proper(X1), proper(X2))
proper(quot(X1, X2)) → quot(proper(X1), proper(X2))
proper(zWquot(X1, X2)) → zWquot(proper(X1), proper(X2))
proper(nil) → ok(nil)
from(ok(X)) → ok(from(X))
cons(ok(X1), ok(X2)) → ok(cons(X1, X2))
s(ok(X)) → ok(s(X))
sel(ok(X1), ok(X2)) → ok(sel(X1, X2))
minus(ok(X1), ok(X2)) → ok(minus(X1, X2))
quot(ok(X1), ok(X2)) → ok(quot(X1, X2))
zWquot(ok(X1), ok(X2)) → ok(zWquot(X1, X2))
top(mark(X)) → top(proper(X))
top(ok(X)) → top(active(X))
active(from(X)) → mark(cons(X, from(s(X))))
active(sel(0, cons(X, XS))) → mark(X)
active(sel(s(N), cons(X, XS))) → mark(sel(N, XS))
active(minus(X, 0)) → mark(0)
active(minus(s(X), s(Y))) → mark(minus(X, Y))
active(quot(0, s(Y))) → mark(0)
active(quot(s(X), s(Y))) → mark(s(quot(minus(X, Y), s(Y))))
active(zWquot(XS, nil)) → mark(nil)
active(zWquot(nil, XS)) → mark(nil)
active(zWquot(cons(X, XS), cons(Y, YS))) → mark(cons(quot(X, Y), zWquot(XS, YS)))
active(from(X)) → from(active(X))
active(cons(X1, X2)) → cons(active(X1), X2)
active(s(X)) → s(active(X))
active(sel(X1, X2)) → sel(active(X1), X2)
active(sel(X1, X2)) → sel(X1, active(X2))
active(minus(X1, X2)) → minus(active(X1), X2)
active(minus(X1, X2)) → minus(X1, active(X2))
active(quot(X1, X2)) → quot(active(X1), X2)
active(quot(X1, X2)) → quot(X1, active(X2))
active(zWquot(X1, X2)) → zWquot(active(X1), X2)
active(zWquot(X1, X2)) → zWquot(X1, active(X2))
from(mark(X)) → mark(from(X))
cons(mark(X1), X2) → mark(cons(X1, X2))
s(mark(X)) → mark(s(X))
sel(mark(X1), X2) → mark(sel(X1, X2))
sel(X1, mark(X2)) → mark(sel(X1, X2))
minus(mark(X1), X2) → mark(minus(X1, X2))
minus(X1, mark(X2)) → mark(minus(X1, X2))
quot(mark(X1), X2) → mark(quot(X1, X2))
quot(X1, mark(X2)) → mark(quot(X1, X2))
zWquot(mark(X1), X2) → mark(zWquot(X1, X2))
zWquot(X1, mark(X2)) → mark(zWquot(X1, X2))
proper(from(X)) → from(proper(X))
proper(cons(X1, X2)) → cons(proper(X1), proper(X2))
proper(s(X)) → s(proper(X))
proper(sel(X1, X2)) → sel(proper(X1), proper(X2))
proper(0) → ok(0)
proper(minus(X1, X2)) → minus(proper(X1), proper(X2))
proper(quot(X1, X2)) → quot(proper(X1), proper(X2))
proper(zWquot(X1, X2)) → zWquot(proper(X1), proper(X2))
proper(nil) → ok(nil)
from(ok(X)) → ok(from(X))
cons(ok(X1), ok(X2)) → ok(cons(X1, X2))
s(ok(X)) → ok(s(X))
sel(ok(X1), ok(X2)) → ok(sel(X1, X2))
minus(ok(X1), ok(X2)) → ok(minus(X1, X2))
quot(ok(X1), ok(X2)) → ok(quot(X1, X2))
zWquot(ok(X1), ok(X2)) → ok(zWquot(X1, X2))
top(mark(X)) → top(proper(X))
top(ok(X)) → top(active(X))
from: {1}
cons: {1}
s: {1}
sel: {1, 2}
0: empty set
minus: {1, 2}
quot: {1, 2}
zWquot: {1, 2}
nil: empty set
The QTRS contained all rules created by the complete Giesl-Middeldorp transformation. Therefore, the inverse transformation is complete (and sound).
from(X) → cons(X, from(s(X)))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
minus(X, 0) → 0
minus(s(X), s(Y)) → minus(X, Y)
quot(0, s(Y)) → 0
quot(s(X), s(Y)) → s(quot(minus(X, Y), s(Y)))
zWquot(XS, nil) → nil
zWquot(nil, XS) → nil
zWquot(cons(X, XS), cons(Y, YS)) → cons(quot(X, Y), zWquot(XS, YS))
from: {1}
cons: {1}
s: {1}
sel: {1, 2}
0: empty set
minus: {1, 2}
quot: {1, 2}
zWquot: {1, 2}
nil: empty set
SEL(s(N), cons(X, XS)) → SEL(N, XS)
MINUS(s(X), s(Y)) → MINUS(X, Y)
QUOT(s(X), s(Y)) → QUOT(minus(X, Y), s(Y))
QUOT(s(X), s(Y)) → MINUS(X, Y)
ZWQUOT(cons(X, XS), cons(Y, YS)) → QUOT(X, Y)
SEL(s(N), cons(X, XS)) → XS
from(s(x0))
zWquot(x0, x1)
s on positions {1}
from on positions {1}
zWquot on positions {1, 2}
SEL(s(N), cons(X, XS)) → U(XS)
U(s(x_0)) → U(x_0)
U(from(x_0)) → U(x_0)
U(zWquot(x_0, x_1)) → U(x_0)
U(zWquot(x_0, x_1)) → U(x_1)
U(from(s(x0))) → FROM(s(x0))
U(zWquot(x0, x1)) → ZWQUOT(x0, x1)
from(X) → cons(X, from(s(X)))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
minus(X, 0) → 0
minus(s(X), s(Y)) → minus(X, Y)
quot(0, s(Y)) → 0
quot(s(X), s(Y)) → s(quot(minus(X, Y), s(Y)))
zWquot(XS, nil) → nil
zWquot(nil, XS) → nil
zWquot(cons(X, XS), cons(Y, YS)) → cons(quot(X, Y), zWquot(XS, YS))
MINUS(s(X), s(Y)) → MINUS(X, Y)
from(X) → cons(X, from(s(X)))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
minus(X, 0) → 0
minus(s(X), s(Y)) → minus(X, Y)
quot(0, s(Y)) → 0
quot(s(X), s(Y)) → s(quot(minus(X, Y), s(Y)))
zWquot(XS, nil) → nil
zWquot(nil, XS) → nil
zWquot(cons(X, XS), cons(Y, YS)) → cons(quot(X, Y), zWquot(XS, YS))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
MINUS(s(X), s(Y)) → MINUS(X, Y)
from(X) → cons(X, from(s(X)))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
minus(X, 0) → 0
minus(s(X), s(Y)) → minus(X, Y)
quot(0, s(Y)) → 0
quot(s(X), s(Y)) → s(quot(minus(X, Y), s(Y)))
zWquot(XS, nil) → nil
zWquot(nil, XS) → nil
zWquot(cons(X, XS), cons(Y, YS)) → cons(quot(X, Y), zWquot(XS, YS))
QUOT(s(X), s(Y)) → QUOT(minus(X, Y), s(Y))
from(X) → cons(X, from(s(X)))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
minus(X, 0) → 0
minus(s(X), s(Y)) → minus(X, Y)
quot(0, s(Y)) → 0
quot(s(X), s(Y)) → s(quot(minus(X, Y), s(Y)))
zWquot(XS, nil) → nil
zWquot(nil, XS) → nil
zWquot(cons(X, XS), cons(Y, YS)) → cons(quot(X, Y), zWquot(XS, YS))
POL(0) = 0
POL(QUOT(x1, x2)) = 2·x1
POL(cons(x1, x2)) = 2 + x1
POL(from(x1)) = 2 + x1
POL(minus(x1, x2)) = 0
POL(nil) = 2
POL(quot(x1, x2)) = 1 + x1 + x2
POL(s(x1)) = 2
POL(zWquot(x1, x2)) = 2·x1 + 2·x2
minus(X, 0) → 0
minus(s(X), s(Y)) → minus(X, Y)
quot(0, s(Y)) → 0
quot(s(X), s(Y)) → s(quot(minus(X, Y), s(Y)))
from(X) → cons(X, from(s(X)))
zWquot(XS, nil) → nil
zWquot(nil, XS) → nil
zWquot(cons(X, XS), cons(Y, YS)) → cons(quot(X, Y), zWquot(XS, YS))
QUOT(s(X), s(Y)) → QUOT(minus(X, Y), s(Y))
from(X) → cons(X, from(s(X)))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
minus(X, 0) → 0
minus(s(X), s(Y)) → minus(X, Y)
quot(0, s(Y)) → 0
quot(s(X), s(Y)) → s(quot(minus(X, Y), s(Y)))
zWquot(XS, nil) → nil
zWquot(nil, XS) → nil
zWquot(cons(X, XS), cons(Y, YS)) → cons(quot(X, Y), zWquot(XS, YS))
U(s(x_0)) → U(x_0)
U(from(x_0)) → U(x_0)
U(zWquot(x_0, x_1)) → U(x_0)
U(zWquot(x_0, x_1)) → U(x_1)
from(X) → cons(X, from(s(X)))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
minus(X, 0) → 0
minus(s(X), s(Y)) → minus(X, Y)
quot(0, s(Y)) → 0
quot(s(X), s(Y)) → s(quot(minus(X, Y), s(Y)))
zWquot(XS, nil) → nil
zWquot(nil, XS) → nil
zWquot(cons(X, XS), cons(Y, YS)) → cons(quot(X, Y), zWquot(XS, YS))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
U(s(x_0)) → U(x_0)
U(from(x_0)) → U(x_0)
U(zWquot(x_0, x_1)) → U(x_0)
U(zWquot(x_0, x_1)) → U(x_1)
from(X) → cons(X, from(s(X)))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
minus(X, 0) → 0
minus(s(X), s(Y)) → minus(X, Y)
quot(0, s(Y)) → 0
quot(s(X), s(Y)) → s(quot(minus(X, Y), s(Y)))
zWquot(XS, nil) → nil
zWquot(nil, XS) → nil
zWquot(cons(X, XS), cons(Y, YS)) → cons(quot(X, Y), zWquot(XS, YS))
SEL(s(N), cons(X, XS)) → SEL(N, XS)
from(X) → cons(X, from(s(X)))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
minus(X, 0) → 0
minus(s(X), s(Y)) → minus(X, Y)
quot(0, s(Y)) → 0
quot(s(X), s(Y)) → s(quot(minus(X, Y), s(Y)))
zWquot(XS, nil) → nil
zWquot(nil, XS) → nil
zWquot(cons(X, XS), cons(Y, YS)) → cons(quot(X, Y), zWquot(XS, YS))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
SEL(s(N), cons(X, XS)) → SEL(N, XS)
from(X) → cons(X, from(s(X)))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
minus(X, 0) → 0
minus(s(X), s(Y)) → minus(X, Y)
quot(0, s(Y)) → 0
quot(s(X), s(Y)) → s(quot(minus(X, Y), s(Y)))
zWquot(XS, nil) → nil
zWquot(nil, XS) → nil
zWquot(cons(X, XS), cons(Y, YS)) → cons(quot(X, Y), zWquot(XS, YS))