0 QTRS
↳1 DependencyPairsProof (⇔)
↳2 QDP
↳3 DependencyGraphProof (⇔)
↳4 QDP
↳5 QDPOrderProof (⇔)
↳6 QDP
↳7 PisEmptyProof (⇔)
↳8 TRUE
from(X) → cons(X, n__from(s(X)))
sel(0, cons(X, Y)) → X
sel(s(X), cons(Y, Z)) → sel(X, activate(Z))
from(X) → n__from(X)
activate(n__from(X)) → from(X)
activate(X) → X
SEL(s(X), cons(Y, Z)) → SEL(X, activate(Z))
SEL(s(X), cons(Y, Z)) → ACTIVATE(Z)
ACTIVATE(n__from(X)) → FROM(X)
from(X) → cons(X, n__from(s(X)))
sel(0, cons(X, Y)) → X
sel(s(X), cons(Y, Z)) → sel(X, activate(Z))
from(X) → n__from(X)
activate(n__from(X)) → from(X)
activate(X) → X
SEL(s(X), cons(Y, Z)) → SEL(X, activate(Z))
from(X) → cons(X, n__from(s(X)))
sel(0, cons(X, Y)) → X
sel(s(X), cons(Y, Z)) → sel(X, activate(Z))
from(X) → n__from(X)
activate(n__from(X)) → from(X)
activate(X) → X
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
SEL(s(X), cons(Y, Z)) → SEL(X, activate(Z))
SEL2 > [activate1, from1] > s1
SEL2: [1,2]
s1: [1]
activate1: multiset
from1: multiset
activate(n__from(X)) → from(X)
activate(X) → X
from(X) → cons(X, n__from(s(X)))
from(X) → n__from(X)
from(X) → cons(X, n__from(s(X)))
sel(0, cons(X, Y)) → X
sel(s(X), cons(Y, Z)) → sel(X, activate(Z))
from(X) → n__from(X)
activate(n__from(X)) → from(X)
activate(X) → X