from(X) → cons(X, from(s(X)))
head(cons(X, XS)) → X
2nd(cons(X, XS)) → head(XS)
take(0, XS) → nil
take(s(N), cons(X, XS)) → cons(X, take(N, XS))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
from(x0)
take(0, x0)
head(cons(x0, x1))
take(s(x0), cons(x1, x2))
sel(s(x0), cons(x1, x2))
2nd(cons(x0, x1))
sel(0, cons(x0, x1))
↳ QTRS
↳ DependencyPairsProof
from(X) → cons(X, from(s(X)))
head(cons(X, XS)) → X
2nd(cons(X, XS)) → head(XS)
take(0, XS) → nil
take(s(N), cons(X, XS)) → cons(X, take(N, XS))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
from(x0)
take(0, x0)
head(cons(x0, x1))
take(s(x0), cons(x1, x2))
sel(s(x0), cons(x1, x2))
2nd(cons(x0, x1))
sel(0, cons(x0, x1))
SEL(s(N), cons(X, XS)) → SEL(N, XS)
TAKE(s(N), cons(X, XS)) → TAKE(N, XS)
2ND(cons(X, XS)) → HEAD(XS)
FROM(X) → FROM(s(X))
from(X) → cons(X, from(s(X)))
head(cons(X, XS)) → X
2nd(cons(X, XS)) → head(XS)
take(0, XS) → nil
take(s(N), cons(X, XS)) → cons(X, take(N, XS))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
from(x0)
take(0, x0)
head(cons(x0, x1))
take(s(x0), cons(x1, x2))
sel(s(x0), cons(x1, x2))
2nd(cons(x0, x1))
sel(0, cons(x0, x1))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
SEL(s(N), cons(X, XS)) → SEL(N, XS)
TAKE(s(N), cons(X, XS)) → TAKE(N, XS)
2ND(cons(X, XS)) → HEAD(XS)
FROM(X) → FROM(s(X))
from(X) → cons(X, from(s(X)))
head(cons(X, XS)) → X
2nd(cons(X, XS)) → head(XS)
take(0, XS) → nil
take(s(N), cons(X, XS)) → cons(X, take(N, XS))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
from(x0)
take(0, x0)
head(cons(x0, x1))
take(s(x0), cons(x1, x2))
sel(s(x0), cons(x1, x2))
2nd(cons(x0, x1))
sel(0, cons(x0, x1))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QDP
SEL(s(N), cons(X, XS)) → SEL(N, XS)
from(X) → cons(X, from(s(X)))
head(cons(X, XS)) → X
2nd(cons(X, XS)) → head(XS)
take(0, XS) → nil
take(s(N), cons(X, XS)) → cons(X, take(N, XS))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
from(x0)
take(0, x0)
head(cons(x0, x1))
take(s(x0), cons(x1, x2))
sel(s(x0), cons(x1, x2))
2nd(cons(x0, x1))
sel(0, cons(x0, x1))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDP
SEL(s(N), cons(X, XS)) → SEL(N, XS)
from(x0)
take(0, x0)
head(cons(x0, x1))
take(s(x0), cons(x1, x2))
sel(s(x0), cons(x1, x2))
2nd(cons(x0, x1))
sel(0, cons(x0, x1))
from(x0)
take(0, x0)
head(cons(x0, x1))
take(s(x0), cons(x1, x2))
sel(s(x0), cons(x1, x2))
2nd(cons(x0, x1))
sel(0, cons(x0, x1))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDPSizeChangeProof
↳ QDP
↳ QDP
SEL(s(N), cons(X, XS)) → SEL(N, XS)
From the DPs we obtained the following set of size-change graphs:
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
TAKE(s(N), cons(X, XS)) → TAKE(N, XS)
from(X) → cons(X, from(s(X)))
head(cons(X, XS)) → X
2nd(cons(X, XS)) → head(XS)
take(0, XS) → nil
take(s(N), cons(X, XS)) → cons(X, take(N, XS))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
from(x0)
take(0, x0)
head(cons(x0, x1))
take(s(x0), cons(x1, x2))
sel(s(x0), cons(x1, x2))
2nd(cons(x0, x1))
sel(0, cons(x0, x1))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
TAKE(s(N), cons(X, XS)) → TAKE(N, XS)
from(x0)
take(0, x0)
head(cons(x0, x1))
take(s(x0), cons(x1, x2))
sel(s(x0), cons(x1, x2))
2nd(cons(x0, x1))
sel(0, cons(x0, x1))
from(x0)
take(0, x0)
head(cons(x0, x1))
take(s(x0), cons(x1, x2))
sel(s(x0), cons(x1, x2))
2nd(cons(x0, x1))
sel(0, cons(x0, x1))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDPSizeChangeProof
↳ QDP
TAKE(s(N), cons(X, XS)) → TAKE(N, XS)
From the DPs we obtained the following set of size-change graphs:
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
FROM(X) → FROM(s(X))
from(X) → cons(X, from(s(X)))
head(cons(X, XS)) → X
2nd(cons(X, XS)) → head(XS)
take(0, XS) → nil
take(s(N), cons(X, XS)) → cons(X, take(N, XS))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
from(x0)
take(0, x0)
head(cons(x0, x1))
take(s(x0), cons(x1, x2))
sel(s(x0), cons(x1, x2))
2nd(cons(x0, x1))
sel(0, cons(x0, x1))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
FROM(X) → FROM(s(X))
from(x0)
take(0, x0)
head(cons(x0, x1))
take(s(x0), cons(x1, x2))
sel(s(x0), cons(x1, x2))
2nd(cons(x0, x1))
sel(0, cons(x0, x1))
from(x0)
take(0, x0)
head(cons(x0, x1))
take(s(x0), cons(x1, x2))
sel(s(x0), cons(x1, x2))
2nd(cons(x0, x1))
sel(0, cons(x0, x1))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
FROM(X) → FROM(s(X))
FROM(s(z0)) → FROM(s(s(z0)))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
FROM(s(z0)) → FROM(s(s(z0)))
FROM(s(s(z0))) → FROM(s(s(s(z0))))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ NonTerminationProof
FROM(s(s(z0))) → FROM(s(s(s(z0))))
FROM(s(s(z0))) → FROM(s(s(s(z0))))